Thread.UncaughtExceptionHandler声明当处理未捕获异常的方法本身抛出异常时,该异常将被忽略:
void 未捕获的异常(线程 t,可抛出 e):
当给定线程由于给定原因而终止时调用的方法
未捕获的异常。
该方法抛出的任何异常都将被 Java 忽略
虚拟机。
然而,当我测试它时,JVM 并没有忽略由未捕获的异常处理程序处理的异常:
public static void main(final String args[]) {
Thread.currentThread().setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
@Override
public void uncaughtException(Thread arg0, Throwable arg1) {
throw new java.lang.RuntimeException("e2");
}
});
throw new RuntimeException("e1");
}
Eclipse 控制台输出(JRE 1.7):
异常: java.lang.RuntimeException 抛出
线程“main”中的 UncaughtExceptionHandler
我发现的另一个奇怪之处是我得到的输出不是来自System.err
。它似乎完全来自另一个流。我通过重定向验证了这一点System.err
to System.out
,但我仍然得到“红色”输出:
public static void main(final String[] args) {
System.setErr(System.out);
System.out.println(System.err == System.out);
System.err.println("this is black color");
try {
throw new Error("test stacktrace color");
} catch (Throwable e) {
e.printStackTrace();
}
try {
Thread.sleep(2500);
} catch (InterruptedException e) {
e.printStackTrace();
}
Thread.currentThread().setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
@Override
public void uncaughtException(Thread t, Throwable e) {
throw new RuntimeException("from handler");
}
});
throw new RuntimeException("from main");
}
输出(粗体表示红色):
true
这是黑色的
java.lang.Error:在 asf.df.main(df.java:13) 处测试堆栈跟踪颜色
异常:从线程“main”中的 UncaughtExceptionHandler 抛出 java.lang.RuntimeException
这些现象的解释是什么?
UncaughtExceptionHandler 中抛出的错误会发生什么情况?预期的(记录的或保证的)行为是什么?