这个是jdk 1.8文档中异常的种族描述
可以看出java异常体系的根类是 throwable, 当在java代码中写throw抛出异常时,后面跟的对象必然是throwable或其子类的对象。
然后往下又分为 exception(异常) 和 error
其中exception异常是指一些可以恢复的异常, 例如常见的nullpointerexception空指针异常。
error指的是一些致命的错误,无法通过程序代码手段恢复的异常,例如outofmemoryerror内存溢出错误。
如果能善用异常机制那么代码使用就会大大提高
本次模拟一个异常实例,验证一下异常的捕获
代码如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
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又将数据状态改为未知异常,影响了结果的判断
最终我将调用方代码合并上去,然后多做了一个捕获
1
2
3
4
5
6
7
8
9
10
11
|
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捕获异常内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/G_whang/article/details/118651143