这个是jdk 1.8文档中异常的种族描述

可以看出java异常体系的根类是 throwable, 当在java代码中写throw抛出异常时,后面跟的对象必然是throwable或其子类的对象。
然后往下又分为 exception(异常) 和 error

其中exception异常是指一些可以恢复的异常, 例如常见的nullpointerexception空指针异常。

error指的是一些致命的错误,无法通过程序代码手段恢复的异常,例如outofmemoryerror内存溢出错误。

如果能善用异常机制那么代码使用就会大大提高

本次模拟一个异常实例,验证一下异常的捕获
代码如下

public class exceptiontest {

    public static void main(string[] args) {

        try{
            int i = subtraction();
            system.out.println(i);
        }catch (exception e){
            system.out.println("异常 exception 被捕获 异常信息为:"+e);
            e.printstacktrace();
        }

    }

    public static int subtraction(){
        int result = 0;
        try {
             result = 10 / 0;
        }catch (runtimeexception e){
            system.out.println("运行异常 runtimeexception 被捕获 异常信息"+e);
            throw new runtimeexception("运行异常");
        }
        return result;
    }

}

我在调用一个方法的时候,该方法会抛出一个runtimeexception 异常
然后我调用此方法的程序可能会有其他处理操作,也做了个try…catch 处理,然后验证 主方法的catch是否会执行
结果证明会执行

因为被调用的方法使用throw new runtimeexception("运行异常");
把异常给抛出来了,上面抓到异常以后就会执行
我就是在工作中犯了此错误,
由于我在被调用方法catch的时候,给程序中的数据赋予,调用失败的状态,结果异常又被调用方给捕获,然后调用方的catch又将数据状态改为未知异常,影响了结果的判断
最终我将调用方代码合并上去,然后多做了一个捕获

public static void main(string[] args) {

        try{
            int a = 100 / 0;
        }catch (runtimeexception e){
            system.out.println("运行异常 runtimeexception 异常信息为:"+e);
            throw new runtimeexception(e);
        }catch (exception e){
            system.out.println("运行异常 exception 异常信息为:"+e);
        }
    }

这次只运行了runtimeexception 的catch 尽管异常已经抛出,但是exception 的catch依旧是没有执行

到此这篇关于java异常级别与捕获的示例代码的文章就介绍到这了,更多相关java捕获异常内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!