junit 断言和 java 自带的断言的对比
从 jdk 1.5 以后,java 就支持使用 assert 关键字进行断言调试,于此同时 junit 也有 Assert 类用于断言调试,我看了下junit 的 Assert 类的内部实现断言的代码,以**Assert.assertNotNull()**举例,方法内部的代码如下:
public static void assertNotNull(String message, Object object) {
// 如果object是空,向assertTrue方法传boolen值为false
assertTrue(message, object != null);
}
public static void assertTrue(String message, boolean condition) {
// 反转boolean的值为true
if (!condition) {
// 抛出 AssertionError 异常,输出错误信息
fail(message);
}
}
public static void fail(String message) {
if (message == null) {
throw new AssertionError();
} else {
throw new AssertionError(message);
}
}
从上面的代码可以看出,调用 junit 的断言,和我们自己写代码抛出AssertionError没有什么区别,甚至个人感觉太复杂了。
而 java 的字段的断言只需要使用 assert 关键字
assert Objects.isNull(null) : "is java assert";
并且在虚拟机的启动参数当中添加 -ea 即可使用断言
junit 的断言与java自带的断言的最大不同之处在于:
- java 自带的断言是可以通过jdk的启动参数来控制是否使用断言功能,java 的assert关键字其实是个“代码中的宏命令”,开启断言这个assert命令就有效,不开启断言就无效,也不会浪费资源。但是也有一个缺点,无法在junit单元测试中使用,原因不明。
- junit的断言,很明显不受jdk的启动参数的控制,在一些只适用于本地测试,但是不适用于线上服务使用的断言,使用的是junit的断言,就会造成资源的浪费,当然,一般来说本地测试通过了,也不会出现什么问题就是。