对trace/debug/info级别的日志输出必须使用条件输出形式或者使用占位符的方式
Posted zhouj850
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了对trace/debug/info级别的日志输出必须使用条件输出形式或者使用占位符的方式相关的知识,希望对你有一定的参考价值。
对trace/debug/info级别的日志输出,必须使用条件输出形式或者使用占位符的方式。
说明: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);
正例:(占位符)为什么用采用这种?这里的占位符是指什么?
以上是关于对trace/debug/info级别的日志输出必须使用条件输出形式或者使用占位符的方式的主要内容,如果未能解决你的问题,请参考以下文章