首先字符串拼接的会这么写:
logger.info("po = "+po.toString)
占位符这么写:
logger.info(“po = {}”,po.toString)
对于占位符的形式而言,只有在我们需要的时候才会提取字符串,这样就会避免创建string对象的时候消耗大量的资源。
因为string对象是不可变的,所以会消耗大量的堆内存,即使我们的生产环境输出的error级别的日志,那拼接字符串的形式还会有大量的字符串对象占用内存,但是当我们用占位符的时候,只有在用到的时候才会动态的创建
简而言之:
占位符的形式会延迟字符串的创建到需要他的时候;
而字符串拼接会在一开始就占用大量内存