slf4j与log4j全面了解

网友投稿 219 2023-07-10


slf4j与log4j全面了解

推荐使用SLF4J(Simple Logging Facade for java)作为日志的api,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。

1、Slf4j优势

与使用apache commons-logging或直接使用log4j相比,SLF4J提供了一个名为参数化日志的高级特性,可以显著提高在配置为关闭日志的情况下的日志语句性能,

log.debug("Found {} records matching filter: '{}'", records, filter);//slf4j

log.debug("Found " + records + " records matching filter: '" + filter + "'");//log4j

可以看出SLF4J的优点有:更简略易读;在日志级别不够时,少了字符串拼接的开销,不会调用对象(records/filter)的toString方法。

Slf4j在1.6.0之后,更是支持了异常堆栈的打印,作为最后一个参数传入即可,基本满足了日志的常见打印场景。

log.error("Failed to format {}", s, e);

2、注意Logger间的继承关系

logger的继承是通过命名来实现的。

子logger会默认继承父logger的appender,将它们加入到自己的Appender中;除非加上了additivity="false",则不再继承父logger的appender。

子logger只在自己未定义输出级别的情况下,才会继承父logger的输出级别。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:第一次接触神奇的Bootstrap基础排版
下一篇:Jdbc的步骤以及简单实现代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~