java用log4j记录异常_使用log4j记录Java中的运行时异常

小编典典

我不确定这是否是你要寻找的,但是有一个终止线程的异常处理程序。它是线程异常未明确捕获的任何异常的处理程序。

默认“未捕获的异常处理程序”只是调用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);

}

}

如果使用的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));

2020-04-18

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值