为什么Log记录日志要先做一个判断
为什么Log记录日志要先做一个判断了?如下。
if (logger.isErrorEnabled()){
logger.error(msg,e);
}
还有就是logger.isDebugEnabled和logger.isInfoEnable 等等?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(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