log4j2&logback打印日志的效率问题【细节3】bean属性拷贝【细节4】

1).在打印日志时,我们可以使用下面的代码:

logger.debug("Entry Number :"+ i + " is "+String.valueOf(entry[i]));

这样做的效率比较低。因为他会遭受到【变量i】和【entry】转换成一个字符串,并且再加上字符串的拼接。这些时间不管你打印不打印这些日志都会消耗。

即有可能你讲DEBUG的模式打印的日志的功能关闭了,但是上面那就话还是会消耗时间。

 

2).但是如果变成下面的代码,就不会消耗时间了:

if(logger.isDebugEnabled()) { 
  logger.debug("Entry number: " + i + " is " + String.valueOf(entry[i]));
}

如果debug模式关闭,就不会消耗时间,如果debug模式是开放的,就会消耗时间。从而提高了效率

 

3).使用Logback中的字符串的占位符

在logback中占位符是一对花括号:【{}】.

对于:

Object entry = new SomeObject(); 
logger.debug("The entry is {}.", entry);

如果日志需要的打印的话,就会将{}变成对应的变量的值。如果不需要打印的话,他也不会消耗时间。如同加上了

if(logger.isDebugEnabled()) {

这句话。提高了效率。

 

4)当然也可有多个变量的值:

logger.debug("The new entry is {}. It replaces {}.", entry, oldEntry);
Object[] paramArray = {newVal, below, above};
logger.debug("Value {} was inserted between {} and {}.", paramArray);

 

5)所以,在打印日志时:为了提高效率:有两种方式:

①加上logger.isDebugEnabled()或者logger.isInfoEnable()等等

②使用占位符。

----------------------------------------------------------------------------------------------------

下面是一个示例:打开debug

095504_8Qcx_1266221.png

095453_X8sc_1266221.png

bean属性拷贝

Bean复制的几种框架性能比较(Apache BeanUtils、PropertyUtils,Spring BeanUtils,Cglib BeanCopier)

cglib是最快的

如果是mapping映射使用: orika

另外还可以使用springside4(各种优秀框架集成)

转载于:https://my.oschina.net/u/1266221/blog/794004

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值