当我多次运行这个程序时,我得到了不同的输出:
public class Demo {
public static void main(String[] args) {
try {
System.out.println("try block");
int a = 10 / 0;
} catch (Exception e) {
System.out.println("catch block");
int a = 10 / 0;
} finally {
System.out.println("finally block");
int a = 10 / 0;
}
}
}
第一个输出:
Exception in thread "main" java.lang.ArithmeticException: / by zero
at kd.demo.Demo2.main(Demo2.java:14)
try block
catch block
finally block
第二个输出:
Exception in thread "main" try block
catch block
finally block
java.lang.ArithmeticException: / by zero
at kd.demo.Demo2.main(Demo2.java:14)
第三个输出:
Exception in thread "main" try block
catch block
finally block
java.lang.ArithmeticException: / by zero
at kd.demo.Demo2.main(Demo2.java:14)
当我多次编译并执行这个程序时,我得到了不同的输出。大多数时候我得到第三个,这不是问题。但是,我对其他输出(第一和第二)感到困惑。
最佳答案
您正在写入 System.out(您的 println 语句)和 System.err(将从 finally block 中引发的未捕获异常中打印的堆栈跟踪)。
屏幕上交错显示的顺序相当不确定。
您可以通过将消息发送到 System.err 而不是 System.out 来“修复”此问题。然后所有内容都会进入同一个流。
关于java - java中异常处理的输出不一致,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29960190/