看开源框架源代码时,经常看到这样的代码:
if (logger.isDebugEnabled()) {
logger.debug(……);
}
有没有思考过为什么是先判断再输出,而不是直接输出?
在阿里巴巴开发手册中有这样的规范:
说明:logger.debug("Processing trade with id: " + id + " and symbol: " + symbol); 如果日志级别是warn,上述日志不会打印,但是会执行字符串拼接操作,如果symbol是对象,会执行toString()方法,浪费了系统资源,执行了上述操作,最终日志却没有打印。 正例:(条件)
if (logger.isDebugEnabled()) {
logger.debug("Processing trade with id: " + id + " and symbol: " + symbol);
}
正例:(占位符)
logger.debug("Processing trade with id: {} and symbol : {} ", id, symbol);