背景
最近公司一直在执行sonar
扫描代码bug
、漏洞及异味,但发现了很对异常处理的问题,大多数是对Java
异常处理不正确导致的,那本文就谈谈Java
的异常是什么?设计者的初衷又是什么?
Exception 介绍
Exception
和Error
都是继承了Throwable
类,在Java
中只有Throwable
类型的实例才可以被抛出(throw
)或者捕获(catch
),它是异常处理机制的基本组成类型。
Exception
和Error
体现了Java
平台设计者对不同异常情况的分类。Exception
是程序正常运行中,可以预料的意外情况,可能并且应该被捕获,进行相应处理。
Error
是指在正常情况下,不大可能出现的情况,绝大部分的 Error 都会导致程序(比如虚拟机自身)处于非正常的、不可恢复状态。既然是不正常情况,所以不便于也不需要捕获,常见的比如OutOfMemoryError
之类,都是Error
的子类。
Exception
异常本身又分为可检查(checkd
)异常和不可检查(uncheckd
)异常。
可检查异常在源代码里必须显式地进行捕获处理,这是编译期检查的一部分。不可检查的Error
是Throwable
,而不是Exception
,通常我在编码过程中编译器会提示如何处理异常,类似于我们常见的try catch
或者继续throw
。
不检查异常就是所谓的运行时异常,类似NullPointerException、ArrayIndexOutOfBoundsException
之类,通常是可以编码过程中避免的代码逻辑错误,具体根据需要来判断是否需要捕获,并不会在编译期强制要求捕获此类异常。
争议点
Checkd Exception
(可检查异常)一直都是Java
语言比较有争议的一个功能。
但Java
可检查异常的提倡者