第77项:不要忽略异常

  尽管这条建议看上去是显而易见的,但是它却常常被违反,因而值得重复提出来。当API的设计者声明一个方法将抛出某个异常的时候,它们是在试图告诉你某些事情。所以,不要忽略它!要忽略一个异常非常容易,只需要将方法调用通过try语句包围起来,并包含一个空的catch块:

// Empty catch block ignores exception - Highly suspect!
try {
    ...
} catch (SomeException e) {
}

  空的catch块会使异常达不到应该有的目的 ,【目的】就是强迫你处理异常的情况。忽略异常就如同忽略火警信号一样——如果把火警信号器关掉了,当真正的火灾发生的时候,就没有人能够看到火警信号了。或许你会侥幸逃过劫难,或许结果是灾难性的。每当看见空的catch块时,应该警钟长鸣。

  在某些情况下,是可以忽略异常的,例如,当关闭FileInputStream的时候忽略异常可能就是合适的。你尚未更改文件的状态,因此无需执行任何恢复操作,并且你已经从文件中读取了所需要的信息,因此没有理由中止正在进行的操作。把异常记录下来还是明智的做法,因为如果这些异常经常发生,你就可以调查异常的原因。如果您选择忽略异常,catch块应该包含一个注释,解释为什么这样做是合适的,并且该变量应该被命名为ignore

Future<Integer> f = exec.submit(planarMap::chromaticNumber);
int numColors = 4; // Default; guaranteed sufficient for any map
try {
    numColors = f.get(1L, TimeUnit.SECONDS);
} catch (TimeoutException | ExecutionException ignored) {
    // Use default: minimal coloring is desirable, not required
}

  本项中的建议同样适用于受检异常和未受检的异常。不管异常代表了可预见的异常条件,还是编程错误,用空的catch块忽略它,将会导致程序在遇到错误的情况下悄然地执行下去。然后,有可能在将来的某个点上,当程序不能在容忍与错误源明显相关的问题时,它就会失败。正确地处理异常能够彻底挽回失败。只要将异常传播给外界,至少会导致程序快速失败,从而保留了有助于调试该失败条件的信息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值