java - 为什么Log记录日志要先做一个判断

 她们都叫我哥 发布于 2022-10-29 09:23

为什么Log记录日志要先做一个判断了?如下。

   if (logger.isErrorEnabled()){
        logger.error(msg,e);
    }
    
 还有就是logger.isDebugEnabled和logger.isInfoEnable 等等?   
1 个回答
  • 换下面这个例子就明白了。

    if (log.isDebugEnabled()) {
        log.debug("log " + param1 + " ...");
    }

    在记录日志时很多情况下都会记录一些参数信息,在使用jcl做为日志接口时难免少不了要拼接字符串,但是日志有不同的级别(level)在线上运行时正常情况是不会将所有日志级别的日志都记录下来。

    在使用jcl时如果不增加日志级别判断。直接这样使用log.debug("log " + param1 + " ...");会产生很多不需要的String对象,这些String实际没有产生作用,浪费了执行时间,同时gc也需要大量回收这种垃圾对象,这也就是在使用jcl时需要增加判断的原因。


    当然我们现在可以直接使用slf4j利用占位符来减少这种if判断。如log.debug("log {} ...", param1)
    slf4j

    2022-10-30 15:51 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有