Java 语言在设计之初就提供了相对完善的异常处理机制,这也是 Java 得以大行其道的原因之一,因为这种机制降低了编写和维护可靠程序的门槛。如今,异常处理机制已经成为现代编程语言的标配。
基本区别
Exception
和 Error
都是继承了 Throwable
类,在 Java 中只有 Throwable
类型的实例才可以被抛出(throw
)或者捕获(catch
),它是异常处理机制的基本组成类型。
Exception
和 Error
体现了 Java 平台设计者对不同异常情况的分类。
-
Exception
是程序正常运行中,可以预料的意外情况,可能并且应该被捕获,进行相应处理。 -
Error
是指在正常情况下,不大可能出现的情况,绝大部分的 Error
都会导致程序(比如 JVM
自身)处于非正常的、不可恢复状态。既然是非正常情况,所以不便于也不需要捕获,常见的比如 OutOfMemoryError
之类,都是 Error
的子类。
Exception 又分为可检查(checked)异常和不检查(unchecked)异常,可检查异常在源代码里必须显式地地进行捕获处理,这是编译期检查的一部分。前面我介绍的不可查的 Error
,是 Throwable
不是 Exception
。
不检查异常就是所谓的运行时异常,类似 NullPointerException
、ArrayIndexOutOfBoundsException
之类,通常是可以编码避免的逻辑错误,具体根据需要来判断是否需捕获,并不会在编译期强制要求。