我已经阅读了几个如何使用UncaughtExceptionHandler
将异常从嵌套线程传递到父线程的示例。目前,我的嵌套线程UncaughtExceptionHandler
会捕获异常。我已将其设置为将异常传递给父线程的默认UncaughtExceptionHandler.uncaughtException(...)
方法。
public void load() {
// Create the nested thread
final Thread loadingThread = new Thread(new Runnable() {
@Override
public void run() {
// Do stuff... throw an exception at some point
throw new RuntimeException("Something has gone horribly wrong!");
}
}
});
// Set up a custom exception handler for the nested thread
class LoadingThreadExceptionHandler implements UncaughtExceptionHandler {
// The parent exception handler
private UncaughtExceptionHandler defaultHandler;
// Constructor to get a handle on the parent's exception handler
public void LoadingThreadExceptionHandler() {
// Check if the parent thread has an exception handler
if (Thread.getDefaultUncaughtExceptionHandler() == null) {
System.out.println("The default handler is null");
}
// Get the parent's default exception handler
defaultHandler = Thread.getDefaultUncaughtExceptionHandler();
return;
}
@Override
public void uncaughtException(Thread t, Throwable e) {
System.out.prinln("This is the nested thread's handler");
// Pass it onto the parent's default exception handler
defaultHandler.uncaughtException(t, e);
}
};
// Set the custom exception handler on the loadingThread
loadingThread.setUncaughtExceptionHandler(new LoadingThreadExceptionHandler());
// Start the thread
loadingThread.start();
return;
}
运行它会产生以下输出:
这是嵌套线程的处理程序
无论出于何种原因,都会调用嵌套的UncaughtExceptionHandler
,但它似乎没有将异常传递给父线程的默认UncaughtExceptionHandler
,因为在此之后没有任何反应。我曾经怀疑父母的默认UncaughtExceptionHandler
可能是null,所以,我在构造函数中添加了一些逻辑来检查并打印一条消息,但这似乎不是案子。我也尝试重写父母的默认异常处理程序,尽管无济于事。
我在这里遗漏了什么吗?在我的生活中,我不能理解为什么父母的uncaughtException(...)
方法似乎永远不会被称为。
答案 0 :(得分:2)
public void LoadingThreadExceptionHandler()
这不是被调用的,因为它不是构造函数。当您调用new LoadingThreadExceptionHandler()
时,将调用no-arg默认构造函数(如果没有构造函数,则由编译器创建)。
要修复它,它应该没有返回类型:
public LoadingThreadExceptionHandler()