eri*_*son 22
我不确定这是否是您正在寻找的,但是有一个终止线程的异常处理程序.它是线程目标未明确捕获的任何异常的处理程序.
默认"未捕获的异常处理程序"只是调用printStackTrace()上Throwable打印的堆栈跟踪System.err.但是,你可以用你自己的替换它UncaughtExceptionHandler来将异常记录到log4j:
class Log4jBackstop implements Thread.UncaughtExceptionHandler {
private static Logger log = Logger.getLogger(Log4jBackstop.class);
public void uncaughtException(Thread t, Throwable ex) {
log.error("Uncaught exception in thread: " + t.getName(), ex);
}
}
Run Code Online (Sandbox Code Playgroud)
如果您正在使用传递Runnable对象的执行程序框架,则其线程可能具有自己的catch块,以防止异常到达未捕获的异常处理程序.如果你想在Runtime那里捕获异常,一种方法是将每个任务包装在一个日志包装器中,如下所示:
class Log4jWrapper {
private final Logger log;
private final Runnable target;
Log4jWrapper(Logger log, Runnable target) {
this.log = Objects.requireNonNull(log);
this.target = Objects.requireNonNull(target);
}
public void run() {
try {
target.run();
} catch(RuntimeException ex) {
log.error("Uncaught exception.", ex);
throw ex;
}
}
}
...
Runnable realTask = ...;
executor.submit(new Log4jWrapper(Logger.getLogger(Whatever.class), realTask));
Run Code Online (Sandbox Code Playgroud)
Luk*_*ard 14
记录未捕获的RuntimeExceptions(或任何未捕获的Throwables)的一种方法是创建一个实现Thread.UncaughtExceptionHandler的类.该类的uncaughtException()方法只是将异常详细信息写入日志.每当未捕获的RuntimeException通过添加行终止线程时,您可以使JVM调用此异常处理程序
Thread.setDefaultUncaughtExceptionHandler(new MyExceptionHandler());
Run Code Online (Sandbox Code Playgroud)
你的代码.
| 归档时间: |
|
| 查看次数: |
21383 次 |
| 最近记录: |