码迷,mamicode.com
首页 > 移动开发 > 详细

【读阿里规约有感】循环体内的字符串连接时,使用StringBuilder的append()和+String的方式比较

时间:2019-09-23 15:13:33      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:uil   public   span   字节   start   编译   string   str   oid   

阿里规约里原话是:

【推荐】循环体内,字符串的连接方式,请使用 StringBuilder 的 append 方法进行扩展。(而不要用+String的方式)
说明:因为反编译出的字节码文件显示每次循环都会 new 出一个 StringBuilder 对象,然后进行
append 操作,最后通过 toString 方法返回 String 对象,造成内存资源浪费。

从这句话得知,用StringBuilder连接字符串比 + 的方式好,因为更少占用内存资源。可是我们怎么才能更加直观的看到性能对比呢?

这时我想到了时间开销对比,我推测前者的运行时间比后者少,于是有了下面的测试代码

@Test
public void mainTest1(){
long startTime1 = System.currentTimeMillis();
StringBuilder str1 = new StringBuilder("start");
for (int i = 0;i < 100000; i++){
str1.append(i);
}
long endTime1 = System.currentTimeMillis();
long time1 = endTime1 - startTime1;
System.out.println("StringBuilder所花时间:" + time1);
String str2 = "start";
long startTime2 = System.currentTimeMillis();
for (int i = 0;i < 100000; i++){
str2 = str2 + i;
}
long endTime2 = System.currentTimeMillis();
long time2 = endTime2 - startTime2;
System.out.println("String++所花时间:" + time2);

}
------------------------------------------------------

SringBuilder所花时间:8
Sring++所花时间:11866

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

显而易见。

 

【读阿里规约有感】循环体内的字符串连接时,使用StringBuilder的append()和+String的方式比较

标签:uil   public   span   字节   start   编译   string   str   oid   

原文地址:https://www.cnblogs.com/gywfight/p/11572088.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!