logger的占位符

      首先要明确,在写代码时,System.out.println() 应该尽量少用甚至不用,否则在一些大型的projects中,如果代码出现问题,很有可能会因为控制台输出内容过多占用太多的内存,最终导致服务挂掉。使用logger可以将log信息打到指定的文件,以文本形式保存。

(1)对于占位符的形式而言,只有在我们需要的时候才会提取字符串,这样就会避免创建string对象的时候消耗大量的资源。

因为string对象是不可变的,所以会消耗大量的堆内存,一旦我们用了字符串拼接,就有大量的字符串占用机器的内存,但是当我们用占位符的时候,只有在用到的时候才会动态的创建
 

(2)logger的占位符即{} ,使用方法也很简单,一个占位符对应一个参数,例如要输出的log中包含0个参数、1个参数、2个参数,使用方法如下:

对于log4j来说,使用logger.debug()消息的时候,如果需要连接字符串,则很麻烦,需要类似这样:

    private static Logger logger = Logger.getLogger(ExchangeService.class);
    logger.debug("你好,我是"+name+",你好呀");

使用这种方式的时候,要写很多+号和双引号"",但如果使用slf4j的话,就会方便很多:

    protected Logger logger = LoggerFactory.getLogger(getClass());
    logger.debug("你好,我是{},你好呀",name);

使用{}占位,然后再将参数紧跟在,后面,这样就省去了很多+号和双引号""。

我很喜欢slf4j的这个优点,那么在写单纯的Java字符串时,除了使用+号,stringbuffer将字符串拼接起来,还有其它便捷的方法可以利用吗,尤其是没有类似slf4j占位符的方法?

答案当然是有的:

    String.format("%s过大,不超过%sM", msg, size)
    String的format方法可以做到。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值