6.2-全栈Java笔记:异常处理机制的分类

全栈Java笔记 2017-08-11

异常分类

JDK中定义了很多异常类,这些类对应了各种各样可能出现的异常事件,所有异常对象都是派生于Throwable类的一个实例。如果内置的异常类不能够满足需要,还可以创建自己的异常类。

图1 异常的分类

Error

Error类层次描述了Java运行时系统内部错误和资源耗尽错误。这类错误是我们无法控制的,同时也是非常罕见的错误。所以在编程中,不去处理这类错误。

Error表明系统JVM已经处于不可恢复的崩溃状态中。我们不需要管他。

图2 java.lang包中Error的类

Error与Exception的区别

1.我开着车走在路上,一头猪冲在路中间,我刹车。这叫一个异常。

2.我开着车在路上,发动机坏了,我停车,这叫错误。系统处于不可恢复的崩溃状态。发动机什么时候坏?我们普通司机能管吗?不能。发动机什么时候坏是汽车厂发动机制造商的事。

Exception

Exception类所有异常类的父类,其子类对应了各种各样可能出现的异常事件。Exception分为:

1.RuntimeException 运行时异常

2.CheckedException编译时异常

RuntimeException运行时异常

派生于RuntimeException的异常,如被0除、数组下标超范围等,其产生比较频繁,处理麻烦,如果显式的声明或捕获将会对程序可读性和运行效率影响很大。 因此由系统自动检测并将它们交给缺省的异常处理程序(用户可不必对其处理)。

这类异常通常是由编程错误导致的,所以在编写程序时,并不要求必须使用异常处理机制来处理这类异常,经常需要通过增加“逻辑处理来避免这些异常”。

【示例1】ArithmeticException异常,试图除以0

public classTest {
public static voidmain(String[] args) {
intb=0;
System.out.println(1/b);
}
}
示例1 ArithmeticException异常

解决如上异常需要修改代码:

public class Test {
public static void main(String[] args) {
int b=0;
if(b!=0){
System.out.println(1/b);
}
}
}

【示例2】NullPointerException异常,当程序访问一个空对象的成员变量或方法,访问一个空数组的成员时发生。怎么处理?

public classTest {
public static voidmain(String[] args) {
String str=null;
System.out.println(str.charAt(0));
}
}
示例2 NullPointerException异常

解决空指针异常,通常是增加非空判断:

public class Test {
public static void main(String[] args) {
String str=null;
if(str!=null){
System.out.println(str.charAt(0));
}
}
}

【示例3】ClassCastException异常

public classTest {
public static voidmain(String[] args) {
Animal a=newDog();
Cat c=(Cat)a;
}
}
classAnimal{
}
classDogextendsAnimal{
}
classCatextendsAnimal{
}
示例3 ClassCastException异常

解决ClassCastException的典型方式:

public class Test {
public static void main(String[] args) {
Animal a=new Dog();
if(ainstanceof Cat){
Catc=(Cat)a;
}
}
}
class Animal{
}
class DogextendsAnimal{
}
class CatextendsAnimal{
}

【示例4】ArrayIndexOutOfBoundsException异常,访问的元素下表超过数组长度

public classTest {
public static voidmain(String[] args) {
int[] arr=new int[5];
System.out.println(arr[5]);
}
}
示例4 ArrayIndexOutOfBoundsException异常

解决数组索引越界异常的方式,增加关于边界的判断:

public class Test {
public static void main(String[] args) {
int[] arr=new int[5];
inta = 5;
if(a<arr.length){
System.out.println(arr[a]);
}
}
}

【示例5】NumberFormatException,数字格式异常!

public classTest {
public static voidmain(String[] args) {
String str = "1234abcf";
System.out.println(Integer.parseInt(str));
}
}
示例5 NumberFormatException异常

数字格式化异常的解决,可以引入正则表达式判断是否为数字:

import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test {
public static void main(String[] args) {
String str ="1234abcf";
Pattern p = Pattern.compile("^\\d+$");
Matcher m = p.matcher(str);
if(m.matches()){//如果str匹配代表数字的正则表达式
System.out.println(Integer.parseInt(str));
}
}
}

Checked Exception已检查异常

所有不是RuntimeException的异常,统称为Checked Exception,又被称为“已检查异常”。 这类异常在编译时就必须做出处理。

图 3 Checked Exception必须处理,否则无法通过编译


「全栈Java笔记」是一部能帮大家从零到一成长为全栈Java工程师系列笔记。笔者江湖人称 Mr. G,10年Java研发经验,曾在神州数码、航天院某所研发中心从事软件设计及研发工作,从小白逐渐做到工程师、高级工程师、架构师。精通Java平台软件开发,精通JAVAEE,熟悉各种流行开发框架。

笔记包含从浅入深的六大部分:

A-Java入门阶段

B-数据库从入门到精通

C-手刃移动前端和Web前端

D-J2EE从了解到实战

E-Java高级框架精解

F-Linux和Hadoop

查看更多主题的豆瓣日记和相册

全栈Java笔记
作者全栈Java笔记
17日记 0相册

全部回应 0 条

添加回应

全栈Java笔记的热门日记

值得一读

    豆瓣
    我们的精神角落
    免费下载 iOS / Android 版客户端