java中为什么把Checked Exception翻译成受检的异常

6.Checked Exception(受检的异常)

马克-to-win:为什么我大胆的把Checked Exception翻译成受检的异常?因为这类异常,编译器检查发现到它后会强令你catch它或throws它(我们之后讲),马克-to-win:而相对于本节前面我们提到的各种比如ArithmeticException,都是unchecked exception(不受检)的异常,unchecked异常都是RuntimeException或者它的子类。马克-to-win:换句话:编译器检查发现到它以后,什么都不管,也什么都不做,直接放行。见下面的例子:



例:1.6.1-本章源码

public class Test {
    void m1_mark_to_win() {
        throw new RuntimeException("divide by 0");
    }
    public static void main(String[] args)   {
        Test t=new Test();
        t.m1_mark_to_win();
    }
}

输出结果:

Exception in thread "main" java.lang.RuntimeException: divide by 0
    at Test.m1_mark_to_win(Test.java:3)
    at Test.main(Test.java:7)

马克-to-win:注意上面一个例子ArithmeticException是个unchecked exception, 所以什么问题都没有,编译器不报错。马克-to-win:但是,当我们把ArithmeticException变成 FileNotFoundException这种checked exception时,就会出现问题。马克-to-win:如下面例:1.6.2,根本就编译不过去。必须变成1.6.3才能运行。




例:1.6.2(编译报错,不能运行)-本章源码


import java.io.FileNotFoundException;

public class Test {
    void m1_mark_to_win() {
        throw new FileNotFoundException();
    }
    public static void main(String[] args)   {
        Test t=new Test();
        t.m1_mark_to_win();
    }
}

在throw new FileNotFoundException();外面,马克-to-win:必须包上一个try catch块儿,程序才能通过编译。




例:1.6.3-本章源码

import java.io.FileNotFoundException;
public class Test {
    void m1_mark_to_win() {
        try {
            throw new FileNotFoundException();
        } catch (FileNotFoundException e) {
            System.out.println(" in catch");
            e.printStackTrace();
        }
    }
    public static void main(String[] args)   {
        Test t=new Test();
        t.m1_mark_to_win();
        System.out.println("马克-to-win:优雅结束");
    }
}

输出结果:
 in catch
马克-to-win:优雅结束
java.io.FileNotFoundException
    at com.Test.m1_mark_to_win(Test.java:6)
    at com.Test.main(Test.java:14)