建议19 : 断言不是鸡肋
基本用法:
assert <布尔表达式>
assert <布尔表达式> : <错误信息>
在布尔表达式为假时,抛出AssertionError错误。
- assert默认是不启用的。
断言的目的是为了能够快速、方便的检查到程序异常,使用用assert关键字。 - assert抛出的异常AssertError是继承自Error的。
断言失败后,JVM抛出的错误是严重的,必须处理。
不可使用的情况:
- 对外公开的方法。即public方法。例子:
public class Client {
public static void main(String[] args) {
StringUtils.encode(null);
}
}
//字符串处理工具类
class StringUtils{
public static String encode(String str){
assert str!=null:"加密的字符串为null"; /*加密处理*/
}
}
调用者合理调用却报错。
2.在执行逻辑代码的情况下。
assert在开发时可以运行,在生产系统中则不需要其运行,所以用assert去处理逻辑永远都不会执行。如下:
public void doSomething (List list, Object element){
assert list.remove(element):"删除元素" + element + "失败"
}
下面三种情况可以使用:
(1)在私有方法中放置assert作为输入参数的校验
在私有方法中可以放置assert校验输入参数,因为私有方法的使用者是作者自己,私有方法的调用者和被调用者之间是一种弱契约关系,或者说没有契约关系,其间的约束是依靠作者自己控制的,因此加上assert可以更好地预防自己犯错,或者无意的程序犯错。
(2)流程控制中不可能达到的区域
这类似于JUnit的fail方法,其标志性的意义就是:程序执行到这里就是错误的,例如:
public void doSomething(){
int i = 7;
while(i >7){
/*业务处理*/
}
assert false:"到达这里就表示错误";
}
(3)建立程序探针
我们可能会在一段程序中定义两个变量,分别代表两个不同的业务含义,但是两者有固定的关系,例如var1=var2*2,那我们就可以在程序中到处设“桩”,断言这两者的关系,如果不满足即表明程序已经出现了异常,业务也就没有必要运行下去了