文章详情页
java - 为什么Log记录日志要先做一个判断
浏览:39日期:2023-12-27 11:04:51
问题描述
为什么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
标签:
java
相关文章:
1. python如何不改动文件的情况下修改文件的 修改日期2. node.js - node_moduls太多了3. angular.js - 不适用其他构建工具,怎么搭建angular1项目4. python - django 里自定义的 login 方法,如何使用 login_required()5. css3 - [CSS] 动画效果 3D翻转bug6. mysql优化 - mysql count(id)查询速度如何优化?7. angular.js - Angular路由和express路由的组合使用问题8. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?9. 主从备份 - 跪求mysql 高可用主从方案10. java8中,逻辑与 & 符号用在接口类上代表什么意思
排行榜
![css3 - [CSS] 动画效果 3D翻转bug](http://www.haobala.com/attached/image/news/202304/110831f073.png)