84669 Lernen von Personen
152542 Lernen von Personen
20005 Lernen von Personen
5487 Lernen von Personen
7821 Lernen von Personen
359900 Lernen von Personen
3350 Lernen von Personen
180660 Lernen von Personen
48569 Lernen von Personen
18603 Lernen von Personen
40936 Lernen von Personen
1549 Lernen von Personen
1183 Lernen von Personen
32909 Lernen von Personen
为什么Log记录日志要先做一个判断了?如下。
if (logger.isErrorEnabled()){ logger.error(msg,e); } 还有就是logger.isDebugEnabled和logger.isInfoEnable 等等?
换下面这个例子就明白了。
if (log.isDebugEnabled()) { log.debug("log " + param1 + " ..."); }
在记录日志时很多情况下都会记录一些参数信息,在使用jcl做为日志接口时难免少不了要拼接字符串,但是日志有不同的级别(level)在线上运行时正常情况是不会将所有日志级别的日志都记录下来。
jcl
level
在使用jcl时如果不增加日志级别判断。直接这样使用log.debug("log " + param1 + " ...");会产生很多不需要的String对象,这些String实际没有产生作用,浪费了执行时间,同时gc也需要大量回收这种垃圾对象,这也就是在使用jcl时需要增加判断的原因。
log.debug("log " + param1 + " ...");
String
gc
当然我们现在可以直接使用slf4j利用占位符来减少这种if判断。如log.debug("log {} ...", param1)slf4j
slf4j
if
log.debug("log {} ...", param1)
换下面这个例子就明白了。
在记录日志时很多情况下都会记录一些参数信息,在使用
jcl
做为日志接口时难免少不了要拼接字符串,但是日志有不同的级别(level
)在线上运行时正常情况是不会将所有日志级别的日志都记录下来。在使用
jcl
时如果不增加日志级别判断。直接这样使用log.debug("log " + param1 + " ...");
会产生很多不需要的String
对象,这些String
实际没有产生作用,浪费了执行时间,同时gc
也需要大量回收这种垃圾对象,这也就是在使用jcl
时需要增加判断的原因。当然我们现在可以直接使用
slf4j
利用占位符来减少这种if
判断。如log.debug("log {} ...", param1)
slf4j