likes
comments
collection
share

Exception与Error

作者站长头像
站长
· 阅读数 15

1. Exception与Error的区别

Exception和Error都继承了Throwable类,在Java中Throwable类型是异常处理机制的基本组成类型,只有Throwable类型的实例才可以被抛出(throw)或者捕获(catch)。

区别如下:

① 处理上的区别:

  • Exception是程序正常运行中,可以预料的意外情况,应该被捕获,进行相应处理。

    Exception分为:

    • 可检查异常(checked): 必须显式地进行捕获处理,编译期会检查,如:IOException

    • 不检查异常(unchecked): 即运行时异常,根据需要来判断是否捕获,不会在编译期强制要求捕获,如:NullPointerException, ArrayIndexOutOfBoundsException

  • Error是在正常情况下,不太可能出现的情况,不需要捕获,绝大部分的Error都会导致程序(比如JVM自身)处于非正常的、不可恢复状态,如:OutOfMemoryError, StackOverflowError

② 类设计上的区别:

Exception与Error

2. 异常处理的原则及经验

① 尽量捕获特定异常,而不是类似Exception的通用异常

原因如下:

  • 捕获特定异常,能具体地体现尽量多的异常信息。
  • 保证不会捕获我们不希望捕获的异常,如希望RuntimeException被扩散出来,而不是被捕获。
  • 非特殊情况,不要捕获Throwable或Error,因为很难保证能正确程序处理OutOfMemoryError。

② 不要吞掉异常

生吞异常,而不把异常抛出来或者输出到日志中,则不能容易判断出哪里抛出了异常以及产生异常的原因。

③ 异常打印,不要使用e.printStackTrace(),不要包含敏感信息。

使用e.printStackTrace()会打印到标准错误流中,比较难判断输出到了哪里。

④ 仅捕获有必要的代码段,尽量不要一个大的try包住整段代码

try-cath代码会产生额外的性能开销,会影响JVM对代码进行优化。