一道面试题

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对象,中间存在若干次数组的重新分配。

参考网址: http://bbs.csdn.net/topics/300099623

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值