栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/415099.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号