几种拼接字符串的效率问题

 今天还遇到了严重的String效率问题,经过修改之后,效果不明显,经查,有以下文章可以解决》

 

每次拼接字符串的时候用习惯了String,从来没想过用其他的class,最近看了看java性能的一些介绍书籍,很多东西以前都没想到,哎,还是经验太少。
拼接字符串,大致有3个class可以用,他们是String, StringBuffer,StringBuilder, StringBuilder是1.5中来代替StringBuffer的,我用的检验方法很简单,

就是
Java代码 复制代码
  1. long start = System.currentTimeMillis();   
  2.     //code here...   
  3.     long end = System.currentTimeMillis();   
  4.     long time = end -start;   
  5.     System.out.println(time);  
 long start = System.currentTimeMillis();
     //code here...
     long end = System.currentTimeMillis();
     long time = end -start;
     System.out.println(time);

其实我也不知道使用别的什么其他方法,许多工具可以检查性能,不过我基本没怎么用过。
    “+=”看起来效率高,比较短小,其实性能远不如append,看代码

Java代码 复制代码
  1. public class StringTest   
  2. {   
  3.     public static void main(String[] args)   
  4.     {   
  5.         long start = System.currentTimeMillis();   
  6.         String s = new String("hello");   
  7.         for (int i = 0; i < 15000; i++)   
  8.         {   
  9.             s+=i;   
  10.         }   
  11.         long end = System.currentTimeMillis();   
  12.         long time = end -start;   
  13.         System.out.println("用String +=拼接字符串的时间"+time);   
  14.            
  15.         long start1 = System.currentTimeMillis();   
  16.         StringBuffer sb = new StringBuffer("hello");   
  17.         for (int i = 0; i < 15000; i++)   
  18.         {   
  19.             sb.append(i);   
  20.         }   
  21.         long end1 = System.currentTimeMillis();   
  22.         long time1 = end1 -start1;   
  23.         System.out.println("用StringBuffer append拼接字符串的时间"+time1);   
  24.            
  25.         long start2 = System.currentTimeMillis();   
  26.         StringBuilder builder = new StringBuilder("hello");   
  27.         for (int i = 0; i < 15000; i++)   
  28.         {   
  29.             builder.append(i);   
  30.         }   
  31.         long end2 = System.currentTimeMillis();   
  32.         long time2 = end2 -start2;   
  33.         System.out.println("用StringBuilder append拼接字符串的时间"+time2);   
  34.     }   
  35. }   
  36. 打印结果:   
  37. 用String +=拼接字符串的时间3984  
  38. 用StringBuffer append拼接字符串的时间31  
  39. 用StringBuilder append拼接字符串的时间0  
public class StringTest
{
	public static void main(String[] args)
	{
		long start = System.currentTimeMillis();
		String s = new String("hello");
		for (int i = 0; i < 15000; i++)
		{
			s+=i;
		}
		long end = System.currentTimeMillis();
		long time = end -start;
		System.out.println("用String +=拼接字符串的时间"+time);
		
		long start1 = System.currentTimeMillis();
		StringBuffer sb = new StringBuffer("hello");
		for (int i = 0; i < 15000; i++)
		{
			sb.append(i);
		}
		long end1 = System.currentTimeMillis();
		long time1 = end1 -start1;
		System.out.println("用StringBuffer append拼接字符串的时间"+time1);
		
		long start2 = System.currentTimeMillis();
		StringBuilder builder = new StringBuilder("hello");
		for (int i = 0; i < 15000; i++)
		{
			builder.append(i);
		}
		long end2 = System.currentTimeMillis();
		long time2 = end2 -start2;
		System.out.println("用StringBuilder append拼接字符串的时间"+time2);
	}
}
打印结果:
用String +=拼接字符串的时间3984
用StringBuffer append拼接字符串的时间31
用StringBuilder append拼接字符串的时间0

    当然这个时间取决于你计算机的速度,不过可以看出,Buffer和Buildr相差无几,而String就慢许多了
原因:
    查看程序的字节码,你就会明白了,原因是String类本身是final类型,他不能更改,所以拼接时,它会使用StringBuffer,并调用append,之后再调用toString方法,每次都要这样,StringBuffer再转换成String时,代价是很大的。这是它慢的主要的一些原因。不仅创立了临时对象StringBuffer,还每次完后再要转成String。
    而 StringBuilder的出现就是用来替换StringBuffer的,所以应该尽可能StringBuilder来拼接,将转为String的数量减至最少,降低对象的创建数,大大提高性能。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在for循环中拼接字符串几种常见的方法。第一种方法是在循环中使用StringStringBuilder对象进行拼接。例如,在每次循环时,将几个字段拼接成一个新的字符串,并赋值给对象。或者在循环外创建一个StringBuilder对象,在每次循环时向该对象中拼接新的内容,循环结束后得到拼接好的字符串。这种方法在每次循环结束后都会创建一个新的字符串对象,可能会占用较多的内存。 另一种方法是在每次循环中拼接字符串后立即使用,并在下一次循环开始时销毁。这种方法可以减少内存的占用。例如,在循环内部使用StringStringBuilder对象进行拼接拼接完成后立即销毁。这样,在下一次循环开始时重新创建一个新的对象进行拼接。这种方法在每次循环结束后都会销毁字符串对象,节约了内存空间。 根据具体的需求和性能要求,选择适合的方法进行字符串拼接。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [StringBuider 在什么条件下、如何使用效率更高?](https://blog.csdn.net/weixin_43144260/article/details/107037127)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值