isdebugenabled_日志框架中为什么有isDebugEnabled方法?

b102b457f120dbf143b62e0101519bff.png

日志框架中为什么有isDebugEnabled方法?

今天坐高的时候突然想起好多年前的遇到的一个面试题,日志文件可以配置日志级别,为什么日志框架中还有isDebugEnabled方法?

如果我们在日志的配置文件配置日志级别是INFO,下面的日志代码是不会有任何输出的,

logger.debug("Processing trade with id: " + id + " symbol: " + symbol);

不执行日志输出,但是会拼接debug方法里面的字符串,为了提供性能,我们要加上isDebugEnabled方法,代码如下:

if (log.isDebugEnabled()) {

log.debug("The log id : " + id + " symbol: " + symbol);

}

今天又看了下阿里巴巴的开发手册,里面也有类似的强制要求,内容如下:

【强制】对trace/debug/info级别的日志输出,必须使用条件输出形式或者使用占位符的方式。 说明:logger.debug("Processing trade with id: " + id + " symbol: " + symbol); 如果日志级别是warn,上述日志不会打印,但是会执行字符串拼接操作,如果symbol是对象,会执行toString()方法,浪费了系统资源,执行了上述操作,最终日志却没有打印。

正例:(条件)

if (logger.isDebugEnabled()) {

logger.debug("Processing trade with id: " + id + " symbol: " + symbol);

}

正例:(占位符)

logger.debug("Processing trade with id: {} symbol : {} ", id, symbol);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值