string str1="1"+"2"+"3"+....+"1000"; 1式
string str2;
for(int i = 1; i <=1000 ;i++)
str2+=i; 2式
stringbuffer str3 = new stringbuffer();
for(int i = 1; i <=1000 ;i++)
str3 = str3.append(i); 3式
1式和2式那个执行速度快?
2式和3式那个执行速度快?
string str1="1"+"2"+"3"+....+"1000"; 1式
这个最快,因为"1"+"2"+"3"+....+"1000"这些链接是在编译时就完成的,不占用运行时间。
string str2;
for(int i = 1; i <=1000 ;i++)
str2+=i; 2式
这个最慢,因为每次循环都要生成一个StringBuilder对象,连接,然后再转为String。
stringbuffer str3 = new stringbuffer();
for(int i = 1; i <=1000 ;i++)
str3 = str3.append(i); 3式
这个只创建一个StringBuffer对象,中间存在若干次数组的重新分配。