美文网首页Effective Java
第57条:只针对异常的情况才使用异常

第57条:只针对异常的情况才使用异常

作者: 明月_48cd | 来源:发表于2017-08-15 19:56 被阅读0次

也许你会碰到如下代码:

这段代码看起来根本不明显,这正是它并没有真正被使用的原因(见55条谨慎的进行优化)
1.设计意图不明显,可读性差
2.使用异常作为遍历结束的条件,企图访问数组之外的元素,用抛出、捕获、忽略数组越界异常的手段来达到终止循环的目的.
下面的标准模式,一目了然.
for (Mountaion m : range) {
m.climb();
}

为什么优先异常的模式,而不是用行之有效标准模式呢?
可能被误导了,企图利用异常机制提高性能,因为jvm每次访问数组都需要判断下标是否越界,他们认为循环终止被隐藏了,但是在foreach循环中仍然可见,这无疑是多余的,应该避免.
上面想法有三个错误:
1.异常机制设计的初衷是用来处理不正常的情况,所以JVM很少对它们进行优化.
2.代码放在try..catch中反而阻止jvm本身要执行的某些特定优化
3.对数组进行遍历的标准模式并不会导致冗余的检查.

现在jvm实现,基于异常模式要比标准模式慢得多.

基于异常模式模糊了代码意图,降低它的性能,并且无法保证正常工作!如果出现bug,模式可能会悄悄失效,并且掩盖这个bug,增加调试过程的复杂性.假设循环中调用某个方法执行不相关数组的越界异常访问,使用合理模式,可以获得完整的异常链,如果基于异常模式,这个bug会捕获到,但是被误解为正常循环终止条件. 案例的经验是,异常只应该使用在异常情况下,它们永远不应该用于正常的控制流中.

优先使用标准的,易于理解的模式,而不是那些声称可以提高性能,弄巧成拙的方法.即使可以提高性能,面对平台不断改进,这种基于异常的模式的优势不可能一直存在,而维护的痛苦却永远存在.

总而言之,异常是为了在异常情况下使用而设计的。不要将它们用于普通的控制流,也不要编写破事它们这么做的API。

相关文章

  • Effective Java 随笔(异常)

    异常第57条:只针对异常的情况使用异常Java程序设计的时候,只针对有异常的情况,才考了使用异常。实际上,基于异常...

  • 第57条:只针对异常的情况才使用异常

    也许你会碰到如下代码: 为什么优先异常的模式,而不是用行之有效标准模式呢?可能被误导了,企图利用异常机制提高性能,...

  • 第 69 条:只针对异常的情况才使用异常

  • 第九章、异常Exception

    第五十七条、只针对异常的情况才使用异常 不要优先使用基于异常的模式:因为异常机制的设计初衷是用于不正常的情况,所以...

  • 八、异常

    57.只针对异常的情况才使用异常 在现代JVM实现上,基于异常的模式比标准模式要慢得多。异常应该只用于异常情况,永...

  • Effective Java-异常

    只针对异常的情况才使用异常 异常应该只用于异常的情况下,它们永远不应该用于正常的控制流 基于异常的模式比标准模式要...

  • EffectiveJava-8-异常

    只针对异常的情况才使用异常 上面代码有什么问题呢? - 试图通过抛出异常并忽略的方式终止无限循环;意图避免for循...

  • Effective java笔记(八),异常

    57、只针对异常的情况才使用异常 在这段代码中,当循环企图访问数组边界之外的元素时,抛出异常,以达到终止无限循环的...

  • EffectiveJava第9章-异常

    第57条:只针对异常的情况处理异常 用抛出(throw)、捕获(catch)、忽略ArrayIndexOutOfB...

  • 第十章,异常

    讨论异常,充分发挥异常的优点,可以提高程序的可读性、可靠性、可维护性 第六十九条 ,只针对异常的情况才使用异常1....

网友评论

    本文标题:第57条:只针对异常的情况才使用异常

    本文链接:https://www.haomeiwen.com/subject/gbjcrxtx.html