java的断言应该在什么情况下用?

书上说是在调试时使用,但我觉得用起来并不方便,有什么技巧么?
具体是怎么用的呢?能举个例子么?我用起来感觉还没throws方便啊……

阅读 17.2k
5 个回答

Java的断言基本没人用,连JVM都是自动关掉的。有JUnit这样的测试框架,基本挤占了assert关键词的生存空间。

其实断言也不是不能用,但是这是一个关键词,一不小心溜进你的生产代码里面,抛个Error给你,你的代码十有八九会崩溃的。所以,就是今天这个样子了。

assert用于确保代码逻辑上不可能发生的事情绝对不发生(比如factory method返回NULL),而exception用于处理一些有可能发生的事情(比如用户输入错误,比如网络链接断开)。

assert如果非真,抛出的是AssertionError,而不是Exception,而Error一般是不catch的,所以它的作用就是在测试的时候early crash,你一旦稳定下来确定不会出现了,在production环境中是可以完全关掉的(去掉JVM参数-ea即可,JVM会用nop代替,不影响性能)。

Exception及其处理往往是业务逻辑的一部分。而Assertion不是。后者应该crash early,而前者不是。

需要注意的是assert是可以被关闭的,所以里面不可以有任何重要、正常的业务逻辑代码的调用。

时代不一样了,基本不用考虑和纠结这个了,你觉得什么好用就用什么,这样才能提高生产力。

@Amao
<<Algorithms, 4th>> 的作者在书中说道在工程实践中使用断言是一种好的编程实践
我觉得使用断言是可以用的的 在自己本机上加上-ea参数就好了 在生产环境上不加-ea

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题