为什么Log记录日志要先做一个判断
澳门新葡京官网
澳门新葡京官网
当前位置 : 澳门新葡京官网 > 新葡京娱乐场

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

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

   if logger.isErrorEnabled{
        logger.errormsg,e;
    }
    
 还有就是logger.isDebugEnabled和logger.isInfoEnable 等等?   

换下面这个例子就明白了。

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

栏目列表

广告位

澳门新葡京官网