sif4j 字符串拼接和占位符的区别

首先字符串拼接的会这么写:
logger.info("po = "+po.toString)

占位符这么写:
logger.info(“po = {}”,po.toString)

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

因为string对象是不可变的,所以会消耗大量的堆内存,即使我们的生产环境输出的error级别的日志,那拼接字符串的形式还会有大量的字符串对象占用内存,但是当我们用占位符的时候,只有在用到的时候才会动态的创建

简而言之:
占位符的形式会延迟字符串的创建到需要他的时候;
而字符串拼接会在一开始就占用大量内存

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章