我发现一个有趣的案例:public static void main(String[] args) { int a =0; int b = 2; int c = 10; int d = 0; int e = 0; try { d=c/b; e=b/a; }catch (ArithmeticException ex){ System.out.println("TEST"); ex.printStackTrace(); } System.out.println(d); }将有两种打印顺序:1个TESTjava.lang.ArithmeticException: / by zero at Chapter10.Test2.main(Test2.java:14)52个java.lang.ArithmeticException: / by zero at Chapter10.Test2.main(Test2.java:14)TEST5但是,当我评论该行时System.out.println("TEST");,将只有一个顺序:5java.lang.ArithmeticException: / by zero at Chapter10.Test2.main(Test2.java:14)所以我想问一下try-catch块的执行顺序是什么顺序?为什么System.out.println(d);在catch发生异常时执行before块?
3 回答
![?](http://img1.sycdn.imooc.com/545868c20001b8c402200220-100-100.jpg)
倚天杖
TA贡献1828条经验 获得超3个赞
默认情况下,Exception.printStackTrace()
使用System.err
as PrintStream
,与as不同System.out
。因此,代码执行的顺序为:
System.out.println("TEST"); ex.printStackTrace(); System.out.println(d);
可能与实际输出不一致。可以肯定的是,5
将在之后打印TEST
。可能会显示异常消息:
前
TEST
在
TEST
和之间5
之后
5
。
添加回答
举报
0/150
提交
取消