java - java中异常处理的输出不一致

标签 java

当我多次运行这个程序时,我得到了不同的输出:

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/

相关文章:

java - 使用 hibernate 和 seam 保持多对多关系

java - 将格式 "yyyy-mm-ddTHH:MM:SS+/-0000"的日期转换为 "yyyy-mm-ddTHH:MM:SSZ"

java - 如何在 Java 中自定义 JSON 字符串的顺序

java - ArrayList 在 do..while 循环中未按预期工作

java - 如何使用 JQuery 附加 servlet 的输出

java - Swing - 下拉面板

java - Google Speech API 中口语的语言代码检测

java - "new"Java Lambda方法引用中的关键字

java - PrintWriter 和 FileWriter 类之间的区别

java - 哪里可以下载 java-x86-windows.dll