转自:https://www.iteye.com/blog/zhukewen-java-1174017java
在项目中咱们常常能够看到这样的代码:并发
if (logger.isDebugEnabled()) {性能
logger.debug(message);this
}debug
有些人不明白为何要这样写。有些人认为这样是为了可以控制日志的输出,对于下面这行代码,日志
logger.debug(message);blog
他们的见解是:若是这样写的话,就算你把日志级别调整为info, 这里也会输出日志。开发
其实,在debug()方法里面,就已经叛断了日志的级别。如下是isDebugEnabled()的源码:get
public boolean isDebugEnabled() { 源码
if(repository.isDisabled( Level.DEBUG_INT))
return false;
return Level.DEBUG.isGreaterOrEqual(this.getEffectiveLevel());
}
如下是debug()的源码:
public void debug(Object message) {
if(repository.isDisabled(Level.DEBUG_INT))
return;
if(Level.DEBUG.isGreaterOrEqual(this.getEffectiveLevel())) {
forcedLog(FQCN, Level.DEBUG, message, null);
}
}
咱们能够看到,在debug()方法里作了跟isDebugEnabled()方法同样的判断。
在这里,咱们不由会想,那咱们凡是要输日志的地方,都不判断isDebugEnabled,直接调debug方法,不更省事吗?
官方的说法是:出于效率考虑,看具体状况而定.
咱们来看下面一行代码:
logger.debug("The money is " + getTotalMoney());
假设咱们的日志级别设置为info,那这句话不会输出日志,但这个方法仍是会调用。要调用这个方法,必须提供参数。getTotalMoney()方法返回的结果就是参数的一部分。假设getTotalMoney()要执行10秒钟,10秒钟后,进入到debug()方法里,碰到了第一个判断:
if(repository.isDisabled(Level.DEBUG_INT))
return;
在这里就返回了。结果是日志虽然没有输出,却花费了10秒钟来构造参数。很显然这里得不偿失的。尽管实际应用中几乎不可能有这种花10秒钟来构造这样一个参数的状况,但若是并发数大的话,这样写仍是会影响系统的性能的。这个时候,就应该写成:
if(logger.isDebugEnabled()){
logger.debug("The money is " + getTotalMoney());
}
若是debug的参数很简单的话,也能够直接写 logger.debug(message)的。官方的说法,执行一次logger.isDebugEnabled()这样的判断花费的时间大概是写日志时间的万分之一.虽然这个比例很小,
可是,程序中的任何地方放到并发的环境下,咱们就得从新考虑了。
因此,我以为,咱们开发的时候, 应该视具体的状况选择不一样的写法。
第一次在这里发文,虽然本身技术很菜,但丑媳妇总归是要见家娘,技术应是百花争呜,不该一家独大,不然全世界就只能是那几个大拿写技术文章了。在这写写本身心得,交流交流技术, 引引玉,总归是件有意义的事。