如何在Java地毯下有效地清除问题

因为软件错误可能使我们在开发人员面前看起来很糟糕,并导致其他人对我们的想法减少,所以最好避免编写错误,快速识别和修复错误或掩盖我们的错误。 有许多博客文章和文章讨论如何避免错误以及如何识别和修复错误,因此,在这篇博客文章中,我将介绍一些在地毯下扫除Java代码库中问题的最有效策略。

吞咽检查异常

当我们不小心将错误引入代码时,异常是让我们放弃的事情之一。 在方法上声明throws子句或catch选中的Exception也很麻烦。 解决这两个问题的方法是,在可能引发该异常RuntimeException执行任何操作的情况下,简单地捕获该异常(即使它是RuntimeException )。 这样可以使API保持简洁,并且几乎没有人可以对已检查的异常进行处理。 通过不对其进行记录或执行任何操作,甚至没有人需要知道它曾经发生过。

注释掉或删除不满意的单元测试

失败的单元测试会分散您的注意力,使您难以确定新功能何时破坏了测试。 当我们通过代码更改破坏了某些内容时,它们也可以显示。 注释掉这些失败的单元测试将使单元测试报告更整洁,并使查看他人的新功能是否破坏单元测试变得更加容易。

在基于JUnit的单元测试中使用

注释掉失败的单元测试似乎很令人厌恶,因此另一种可能更令人愉悦的选择是使用@Ignore批注来注释基于JUnit的失败单元测试方法。

完全删除个别测试

如果用@Ignore注释掉一个损坏的测试或用@Ignore注释一个损坏的测试是不令人满意的,因为有人仍然可以检测到我们已经破坏了一个单元测试,我们可以简单地完全删除有问题的单元测试。

注释违规断言

我们不必注释掉或删除整个测试。 它就像在单元测试方法中注释掉或删除assert语句一样简单。 该方法每次都可以成功执行并运行,因为没有断言意味着没有办法失败。 当单元测试方法非常长且令人费解,从而不容易发现缺少断言时,这特别有效。

分散无用和冗余测试的噪音

注释单元测试,使用@Ignore注释基于JUnit的单元测试,甚至删除单元测试对于在Java底下扫除问题的策略可能也太明显了。 为了使这些变得不那么明显,另一种有效的策略是在同一单元测试类中编写许多不必要的和多余的测试方法,以便看起来正在进行全面的测试,但实际上只有一小部分功能(我们知道的子集是工作)正在测试中。

编写单元测试,即使不正确,也可以“证明”您的代码是正确的

我们可以利用以下事实:单元测试只能测试单元测试的作者认为被测软件的预期行为,从而编写能够证明我们的代码正确的单元测试。 如果提供2和2时,我们将两个整数相加的代码意外返回5的和,我们可以简单地将单元测试中的预期结果也设置为5。会显示漂亮的单元测试报告,而不必是明智的。

避免记录详细信息

日志可能会暴露一个人的软件问题,而应对这种风险的有效方法是完全不进行日志记录,仅记录常规操作和结果,并在记录的消息中保留详细信息(尤其是上下文)。 过多记录平凡的细节也可能使任何更有意义的消息模糊,这些消息可能会揭示我们代码的弱点。

避免使用描述性的

一个描述性的toString()方法可能会过多地揭示任何给定实例的状态,并揭示我们的错误。 不覆盖Object.toString()可能会使识别问题和将问题与任何给定的代码或开发人员相关联变得更加困难。 跟踪问题所需的额外时间使您有更多时间进入下一个项目,然后才发现是您的代码有问题。 如果编写的Java类使用描述性的toString()扩展了类,则可以在扩展类中覆盖该方法以不执行任何操作(有效地删除可能导致问题的toString()输出)。 如果希望它看起来像从未在继承层次结构中实现过,请确保扩展类的toString()方法返回System.identityHashCode(this) 。

不要让

NullPointerException可能是Java开发人员处理的最常见的异常。 这些特别危险,因为它们通常会揭示代码的弱点。 try仅包装每一行代码的一种策略– catch并简单吞下异常(包括NPE)。 另一个不太明显的策略是通过从不返回或传递null来避免NPE。 有时,可以使用明显的默认值代替null (例如,空的String或collection),但有时我们必须更有创造力,以避免null 。 在此处可以使用“默认”非null值代替null 。 关于如何处理此任意非null默认值,有两种思路。 一种方法是使用数据集中最常见的值作为默认值,因为如果仍然很常见,那么当该值中出现更多的值并且您更有可能拥有看起来像这样的代码时,可能不会注意到该值。处理该共同价值而无任何意外。 另一方面,如果您拥有一个几乎从未使用过的值,那么它可以成为一个很好的默认值,因为受它影响的代码(尤其是经过良好测试的代码)可能比通常期望的值少。

结论

当我回顾这些策略以扫除底层Java代码问题时,我注意到了一些重复出现的主题。 就暴露我们软件的弱点而言,异常,日志记录和单元测试特别麻烦,因此,有效地“发现我们的足迹”的大多数方式都与异常,日志记录和单元测试的处理有关就不足为奇了。

翻译自: https://www.javacodegeeks.com/2017/04/effectively-sweep-problems-rug-java.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/350884.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python多线程_python多线程:控制线程数量

背景前段时间学习了python的多线程爬虫,当时爬取一个图片网站,开启多线程后,并没有限制线程的数量,也就是说,如果下载1000张图片,会一次性开启1000个子线程同时进行下载 现在希望控制线程数量&#xff…

ubuntu 添加用户、用户组

添加用户 useradd xxx -m 创建一个xxx的用户 sudo passwd xxx 设置xxx用户的密码 su xxx 切换到xxx用户 su – xxx 切换到xxx用户,且家目录变为xxx家目录 whoami 看用户名 who 查看登录用户 exit …

python实践系列之(一)安装 python/pip/numpy/matplotlib

1.下载并安装Python3.4 在官网下载即可:Python官网 图1-1 图1-2打开Python图形界面: 图1-3 输入 2345,回车,出现如图,说明安装成功。 图1-42.安装pip (1)查看是否已安装pip 进入cmd命令窗口&…

2019-04(1)(Python学习)

9.1 迭代器 创建迭代器的3种方法: 方法一: 容器对象添加 __iter__() 和 __next__() 方法(Python 2.7 中是 next());__iter__() 返回迭代器对象本身 self,__next__() 则返回每次调用 next() 或迭代时的元素&…

ubuntu 查看进程信息

查看进程信息 ps ps -aux 查看所有进程,每行一个程序 top 显示当前运行程序 kill 98 (98为PID号,) kill -9 98 (强制杀死98)

浏览器崩溃_字节跳动程序员28岁身价上亿,财务自由宣布退休;微软最新系统再迎“喜报”:更多用户的浏览器开始崩溃...

新闻1:字节跳动程序员28岁身价上亿,财务自由宣布退休最近字节跳动前员工郭宇火了。原因是他在今年二月份发了一条微博。大概是说他在28岁的年纪实现了财务自由,然后选择了退休。郭宇本来是字节跳动的一名程序员,但现在已经离职去往…

Python图像处理库PIL中图像格式转换(一)

在数字图像处理中,针对不同的图像格式有其特定的处理算法。所以,在做图像处理之前,我们需要考虑清楚自己要基于哪种格式的图像进行算法设计及其实现。本文基于这个需求,使用Python中的图像处理库PIL来实现不同图像格式的转换。 对…

spring 构造函数注入_Spring构造函数注入和参数名称

spring 构造函数注入在运行时,除非在启用了调试选项的情况下编译类,否则Java类不会保留构造函数或方法参数的名称。 这对于Spring构造函数注入有一些有趣的含义。 考虑以下简单的类 package dbg; public class Person {private final String first;pr…

C#基础加强(8)之委托和事件

委托 简介 委托是一种可以声明出指向方法的变量的数据类型。 声明委托的方式 格式&#xff1a; delegate <返回值类型> 委托类型名(参数) &#xff0c;例如&#xff1a; delegate void MyDel(string str) 。 // 注意&#xff1a;这里除了前面的 delegate 关键字&#xff…

模板类的析构函数如何写_顶尖文案如何写?这6大模板、29个方法,奥美大咖都在用!|优惠最后1天...

敲黑板划重点&#xff1a;《顶尖文案训练营》第5期将于2月20日(正月十六)开班&#xff0c;现在报名享受春节特惠8折优惠&#xff0c;今天是优惠最后1天&#xff01;先到先得&#xff0c;速速报名抢位&#xff5e;马上就是2.14情人节了&#xff0c;馒火火在这里提前祝大家情人节…

ubuntu 查看日历,日期

cal 查看当前月日历 cal -y 2008 查看2008年日历 cal -y 2008 > 123.txt 打印到123.txt date 当前日期具体时间 date “%y年%m月%d日”

有效的Java –所有对象通用的方法

所有对象共有的方法&#xff08;第3章&#xff09; 这是Joshua Blochs的《 有效的Java》第3章的简短摘要。我仅包括与自己相关的项目。 一般 等值合约将等价关系描述为&#xff1a; x.equals(null) false 自反 – x.equals(x) true 对称 –如果x.equals(y) true则y.equa…

几种页面置换算法

地址映射过程中&#xff0c;若在页面中发现所要访问的页面不再内存中&#xff0c;则产生缺页中断。当发生缺页中断时操作系统必须在内存选择一个页面将其移出内存&#xff0c;以便为即将调入的页面让出空间。而用来选择淘汰哪一页的规则叫做页面置换算法。常见的置换算法有&…

win7摄像头怎么开_win7网络连接不可用怎么办

win7网络连接不可用怎么办&#xff1f;网络出现故障最常见的就是网络明明连接上&#xff0c;但是依然提示网络连接不可用&#xff0c;小白系统遇到最常见的就是使用win7系统的用户反馈的&#xff0c;下面让小白系统教你解决win7网络连接不可用的问题吧。首先我们判断网络状态是…

cmake--安装

一&#xff0c; 目录结构 ├── cmake-examples.conf├── CMakeLists.txt├── include│ └── installing│ └── Hello.h└── src ├── Hello.cpp └── main.cpp * link:CMakeLists.txt[] - Contains the CMake commands yo…

ubuntu 关机重启

关机&#xff0c;重启 reboot &#xff08;重启&#xff09; shutdown -h now &#xff08;立刻关机&#xff09; shutdown -h 10 &#xff08;10min后立刻关机&#xff09; shutdown -h 20:05 &#xff08;今天20:05立刻关机&#xff09;

excel合并两列内容_excel新手问题:怎么把两列数据合并到一起?用这个公式

今天看见有新手在问&#xff1a;怎么把两列数据合并到一起&#xff1f;其实&#xff0c;这种情况在工作中会经常遇到&#xff0c;但很多人可能还在用复制粘贴的方法。只要掌握最简单的一个函数公式&#xff0c;就可以实现快速两列合并。第一步&#xff1a;掌握“&”运算符使…

Pycharm Anaconda 安装dlib

由于采用python3.7安装会出现各种问题&#xff0c;两种解决方法。 1&#xff09;安装Cmake boost等&#xff08;不推荐&#xff0c;麻烦且不容易成功&#xff09;。 2&#xff09;安装Anaconda&#xff0c;创建一个python3.6的环境。 这里使用第二种。 一、安装Anaconda 。 方法…

java 使用jasper_使用Jasper Reports以Java创建报告

java 使用jasper上周&#xff0c;我试图使用Jasper创建报告。 在这篇文章中&#xff0c;我将记录一些资源和链接&#xff0c;以便对任何寻求类似信息的人都有用。 我将介绍Jasper报告&#xff0c;示例和Dynamic Jasper的生命周期。 Jasper Reports是世界上最受欢迎的开源报告…