Java中的异常(checked异常和unchecked异常)

目录

Java的异常层次结构

 最常用的五种RuntimeException

unchecked异常(运行时异常)和checked异常(编译时异常)的区别

为什么要对unchecked异常和checked异常进行区分?


Java的异常层次结构

要想明白Java中checked Exception和unchecked Exception的区别,我们首先来看一下Java的异常层次结构。 

Java中的异常(checked异常和unchecked异常)_第1张图片
  这是一个简化的Java异常层次结构示意图,需要注意的是所有的类都是从Throwable继承而来,下一层则分为两个结构,Error和Exception。其中Error类层次描述了Java运行时系统的内部错误和资源耗尽错误,这种错误除了简单的报告给用户,并尽力阻止程序安全终止之外,一般也米有别的解决办法了。

 最常用的五种RuntimeException

Java中的异常(checked异常和unchecked异常)_第2张图片

unchecked异常(运行时异常)和checked异常(编译时异常)的区别

Java 定义了两种异常(C#只有unchecked异常):

  - Checked exception: 继承自 Exception 类。代码需要处理 API 抛出的 checked exception,要么用 catch 语句,要么直接用 throws 语句抛出去。可以理解为编译时异常。

  - Unchecked exception: 也称 RuntimeException,它也是继承自 Exception。但所有 RuntimeException 的子类都有个特点,就是代码不需要处理它们的异常也能通过编译,所以它们称作 unchecked exception。RuntimeException(运行时异常)不需要try...catch...或throws 机制去处理的异常。运行时异常。

将派生于Error或者RuntimeException的异常称为unchecked异常,所有其他的异常成为checked异常。尽管,这个定义十分简单,但是RuntimeException却是一个非常让人容易混淆的观念,似乎我们所有的异常都是在程序运行的过程中。我《Effective Java》中关于Ru ntimeException异常的阐述也不是那么尽如人意,

Use checked exceptions for recoverable conditions and runtime exceptions for programming errors (Item 58 in 2nd edition)

不过从这句话中我们可以简单引申一下,也就是说,如果出现了RuntimeException,就一定是程序员自身的问题。比如说,数组下标越界和访问空指针异常等等,只要你稍加留心这些异常都是在编码阶段可以避免的异常。如果你还是觉得这两个概念不好区分,那么“最暴力“的方法就是将常见的RuntimeException背下来,这样就可以省去很多判断的时间。

为什么要对unchecked异常和checked异常进行区分?

原因其实很简单,编译器将检查你是否为所有的已检查异常提供了异常处理机制,比如说我们使用Class.forName()来查找给定的字符串的class对象的时候,如果没有为这个方法提供异常处理,编译是无法通过的。 

Java中的异常(checked异常和unchecked异常)_第3张图片
 
————————————————
版权声明:本文为CSDN博主「崩了呀」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/vooDOTA/article/details/88292837

你可能感兴趣的:(java基础)