改善Java程序建议19

建议19 : 断言不是鸡肋

基本用法:
assert <布尔表达式>
assert <布尔表达式> : <错误信息>
在布尔表达式为假时,抛出AssertionError错误。

  1. assert默认是不启用的。
    断言的目的是为了能够快速、方便的检查到程序异常,使用用assert关键字。
  2. assert抛出的异常AssertError是继承自Error的。
    断言失败后,JVM抛出的错误是严重的,必须处理。

不可使用的情况:

  1. 对外公开的方法。即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,那我们就可以在程序中到处设“桩”,断言这两者的关系,如果不满足即表明程序已经出现了异常,业务也就没有必要运行下去了

你可能感兴趣的:(改善Java程序建议19)