证明StringBuffer线程安全,StringBuilder线程不安全

测试思想

分别用1000个线程写StringBuffer和StringBuilder,
使用CountDownLatch保证在各自1000个线程执行完之后才打印StringBuffer和StringBuilder长度,
观察结果。

测试代码

	@Test
	public void testStringBuilderAndStringBuffer(){
		//证明StringBuffer线程安全,StringBuilder线程不安全
		StringBuffer stringBuffer = new StringBuffer();
		StringBuilder stringBuilder = new StringBuilder();
		CountDownLatch latch1 = new CountDownLatch(1000);
		CountDownLatch latch2 = new CountDownLatch(1000);
		for(int i=0;i<1000;i++){
			new Thread(new Runnable() {
				
				@Override
				public void run() {
					try {
							stringBuilder.append(1);					
							
						} catch (Exception e) {
						e.printStackTrace();
						} finally {
				            latch1.countDown();
						} 
				}
			}).start();
		}
		for(int i=0;i<1000;i++){
			new Thread(new Runnable() {
				
				@Override
				public void run() {
					
					try {
							stringBuffer.append(1);	
																			
						} catch (Exception e) {
						e.printStackTrace();
						} finally {
				            latch2.countDown();
						}
					
				}
			}).start();
		}
		try {
			latch1.await();
			System.out.println(stringBuilder.length());
			latch2.await();			
			System.out.println(stringBuffer.length());
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
	}

结果

StringBuffer不论运行多少次都是1000长度。
StringBuilder绝大多数情况长度都会小于1000。
StringBuffer线程安全,StringBuilder线程不安全得到证明。

源码分析

打开StringBuffer源码就会发现所有写操作都被synchronized修饰了,所以所有修改操作都是串行的。
而StringBuilder的写操作则没有使用synchronized进行修饰,也不包含其他串行化修改的算法。
  • 7
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值