StringBuffer和StringBuilder的性能对比

StringBuffer 和 StringBuilder的比较

  • 相同点
  1. 继承层次相同
  2. 底层都是用字符数组实现,字符串都是可变的;
  3. 都是将大部分操作委托给父类;
  4. 初始容量都是16和扩容机制都是"旧容量*2+2"
  • 不同点
  1. StringBuffer是线程安全的,StringBuilder不是线程安全的。
  2. StringBuffer从JDK1.0就有了,StringBuilder是JDK5.0增加的
  3. StringBuffer比StringBuilder多了一个toStringCache字段,用来在toString方法中进行缓存。在重复调用toString()时能提升效率
  4. 由于StringBuilder没有考虑同步,在不会出现线程安全问题的情况下,性能上StringBuilder应该要优于StringBuffer

那么,性能究竟差不多呢? 以下是性能测试代码

    
    	public static void main(String[] args) {
    		
    		int loop = 999999;
    		String str = "abcdefg";
    		
    		testStringBuffer(loop, str);
    		testStringBuilder(loop, str);
    	}
    	
    	public static void testStringBuffer(int loop,String str) {
    		StringBuffer sbBuffer = new StringBuffer();
    		
    		long begin = System.currentTimeMillis();
    		
    		for(int i = 0 ;  i < loop ; i++) {
    			sbBuffer.append(str);
    		}
    		
    		long end = System.currentTimeMillis();
    		
    		System.out.println("StringBuffer:  "+ (end - begin));
    	}
    	
    	public static void testStringBuilder(int loop,String str) {
    		StringBuilder sbBuilder = new StringBuilder();
    		
    		long begin = System.currentTimeMillis();
    		
    		for(int i = 0 ;  i < loop ; i++) {
    			sbBuilder.append(str);
    		}
    		
    		long end = System.currentTimeMillis();
    		
    		System.out.println("StringBuilder:  "+ (end - begin));
    	}

首先,拼接的字符长度不变,看下append次数对性能的影响

这里写图片描述

总体上看,StringBuffer花费的时间大概是StringBuilder的三倍。

append次数不变,改变拼接的字符长度

这里写图片描述

这里改拼接字符长度就是str的长度,
可以看出, 字符长度越大,消耗的时间越接近。

总结

StringBuilder 总是会比StringBuffer的性能要高上一些。
但StringBuffer也不会差上太多。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黑风风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值