加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 如何使用logger打印异常?

发布时间:2020-12-14 05:10:38 所属栏目:Java 来源:网络整理
导读:我有一种情况,我想使用记录器打印捕获在catch块中的所有异常. try { File file = new File("C:className").mkdir(); fh = new FileHandler("C:classNameclassName.log"); logger.addHandler(fh); logger.setUseParentHandlers(false); SimpleFormatter
我有一种情况,我想使用记录器打印捕获在catch块中的所有异常.
try {
        File file = new File("C:className").mkdir();
        fh = new FileHandler("C:classNameclassName.log");
        logger.addHandler(fh);
        logger.setUseParentHandlers(false);
        SimpleFormatter formatter = new SimpleFormatter();
        fh.setFormatter(formatter);
    } catch (Exception e) {
        logger.info(e);
    }

我得到错误记录器不能应用于java.io.Exception …

我关心的是如果我在try block中做这么多事情,我只保留一个catch块作为catch(Exception e),那么有没有什么办法使用logger来打印捕获catch块中的任何类型的异常?
注意:我们使用java.util.logging.Logger API

请指导我…谢谢先生

解决方法

你应该明白你正在使用哪个记录器.

org.apache.commons.logging.Log接口具有方法void error(Object message,Throwable t)(和方法void info(Object message,Throwable t)),它将堆栈跟踪与自定义消息一起记录. Log4J实现也有这个方法.

所以,大概你需要写:

logger.error("BOOM!",e);

如果您需要使用INFO级别进行登录(但是,这可能是一个奇怪的用例),那么:

logger.info("Just a stack trace,nothing to worry about",e);

希望它有帮助.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读