PrintStackTrace 导致我的程序崩溃。为什么?

PrintStackTrace is causing my program to crash. Why?

我编写了一些简单的代码,它应该工作得很好。问题是,它没有。我花了一些时间才弄清楚数字格式异常的原因。显然,当我尝试键入字母而不是数字时,它应该要求我再次重新输入,但它崩溃了。但是当我删除 e.printStackTrace();它工作得很好。谁能告诉我为什么?

import java.util.Scanner;

public class Test {

public static boolean isInteger(String strNumber) {
    try {
        int number = Integer.parseInt(strNumber);
        if(number > 0) {
            return true;
        }
        return false;
    } catch (NumberFormatException e) {
        e.printStackTrace();

        return false;
    }

}

public static void main(String[] args) {

    String numberString = null;
    int number = 0;
    Scanner scanner = new Scanner(System.in);
    do {
        System.out.println("Enter integer:");
        numberString = scanner.nextLine();

    }   while(!isInteger(numberString));

       number = Integer.parseInt(numberString);
       System.out.println("Your number is: " + number);
       scanner.close();
   }

}

我相信你的程序还是运行。 e.printStackTrace() 显示与您的程序在未捕获到异常时相同类型的输出。 示例:

`java.lang.NumberFormatException: For input string: "asdf"
    at java.lang.NumberFormatException.forInputString(Unknown Source)
    at java.lang.Integer.parseInt(Unknown Source)
    at java.lang.Integer.parseInt(Unknown Source)
    at Test.isInteger(Test.java:7)
    at Test.main(Test.java:29)`

此外,您可能在调试输出后看不到 "Enter integer: ",因为它发送到的流 System.err 与常规打印流 System.out 是分开的。这意味着有时,打印到 System.err 和 System.out 的顺序并不总是与它们被调用的顺序相同。

所有这些都是说您的程序可能仍然 运行。它看起来就像是崩溃,因为 e.printStackTrace() 打印的信息与发生导致崩溃的未捕获异常时得到的信息相同。