StringBuilder,StringBuffer,与String连接字符串对比

  之前Debug代码时,发现字符串相加会变成StringBuffer.append,当时以为目前虚拟机已经可以将String相加优化的跟StringBuffer一样了,另外由于StringBuffer是线程安全的,而StringBuilder不是,因此后者会更快些。那么这些推断都争取吗?

 

public static void main(String[] args) {
		int k=100000;
		for (int j = 0; j < 100; j++) {
			long a=genTime();
			StringBuffer sBuffer=new StringBuffer();
			for(int i=0;i<k;i++){
				 sBuffer.append("a");
			}
			long b=genTime();
			System.out.println("Sb="+(b-a));
			long c=genTime();
			StringBuilder sBuilder=new StringBuilder();
			for(int i=0;i<k;i++){
				sBuilder.append("a");
			}
			long d=genTime();
			System.out.println("Sb="+(d-c));
			long e=genTime();
			String string = null;
			for (int i = 0; i < k; i++) {
				string+="a";
			}
			long f=genTime();
			System.out.println("str="+(f-e));
		}
		

	}

	private static long genTime() {
		return System.currentTimeMillis();
	}
 

 

MaxOs上的虚拟机里的UbuntuX64,Openjdk6结果:

Sb=38

Sb=45

str=7268

Sb=30

Sb=2

str=7204

Sb=2

Sb=2

str=7178

Sb=2

Sb=3

str=7190

Sb=3

Sb=3

str=7444

Sb=2

Sb=2

str=7746

Sb=2

Sb=2

str=7297

Sb=2

Sb=3

str=7283

Sb=2

Sb=3

str=7267

Sb=2

Sb=2

str=7149

Sb=2

Sb=3

str=7151

Sb=2

Sb=2

str=7215

Sb=2

Sb=3

str=7157

Sb=3

Sb=3

str=7297

Sb=1

Sb=2

str=7249

Sb=2

Sb=2

str=7657

Sb=2

Sb=3

str=7217

Sb=2

Sb=3

str=7817

Sb=2

Sb=2

str=7580

Sb=2

Sb=2

str=7200

Sb=2

Sb=3

str=7669

Sb=2

Sb=3

str=7421

Sb=2

Sb=2

str=7634

Sb=2

Sb=3

str=7394

Sb=3

Sb=3

str=7348

Sb=2

Sb=3

str=7335

Sb=2

Sb=3

str=7251

Sb=3

Sb=2

str=7170

Sb=3

Sb=2

str=7238

Sb=2

Sb=3

str=7227

Sb=2

Sb=2

str=7227

Sb=2

Sb=2

str=7570

Sb=2

Sb=2

str=7551

Sb=2

Sb=2

str=7453

Sb=2

Sb=2

str=7205

Sb=2

Sb=2

str=7194

Sb=2

Sb=3

str=7208

Sb=1

Sb=2

str=7238

Sb=2

Sb=3

str=7161

Sb=2

Sb=2

str=7310

Sb=2

Sb=2

str=7208

Sb=3

Sb=2

str=7327

Sb=2

Sb=3

str=7541

Sb=4

Sb=4

str=7819

Sb=2

Sb=3

str=7200

Sb=2

Sb=2

str=7187

Sb=2

Sb=3

str=7311

Sb=2

Sb=2

str=7404

Sb=2

Sb=2

str=7305

Sb=2

Sb=3

str=7477

Sb=2

Sb=2

str=7929

Sb=2

Sb=2

str=7236

Sb=2

Sb=2

str=7512

Sb=2

Sb=3

str=7686

Sb=2

Sb=2

str=7325

Sb=2

Sb=2

str=7229

Sb=2

Sb=2

str=7501

Sb=2

Sb=2

str=7356

Sb=1

Sb=2

str=7292

Sb=2

Sb=2

str=7231

Sb=3

Sb=3

str=7434

Sb=2

Sb=2

str=7294

Sb=2

Sb=2

str=7187

Sb=2

Sb=2

str=7186

Sb=2

Sb=3

str=7192

Sb=2

Sb=2

str=7145

Sb=2

Sb=3

str=7215

Sb=2

Sb=2

str=7193

Sb=1

Sb=2

str=7163

Sb=2

Sb=2

str=7168

Sb=2

Sb=3

str=7163

Sb=2

Sb=3

str=7248

Sb=2

Sb=2

str=7188

Sb=1

Sb=2

str=7169

Sb=2

Sb=3

str=7226

Sb=2

Sb=3

str=7202

Sb=2

Sb=2

str=7195

Sb=2

Sb=2

str=7238

Sb=2

Sb=2

str=7153

Sb=3

Sb=2

str=7182

Sb=2

Sb=2

str=7254

Sb=3

Sb=2

str=7189

Sb=1

Sb=2

str=7171

Sb=2

Sb=3

str=7183

Sb=2

Sb=2

str=7182

Sb=2

Sb=2

str=7182

Sb=3

Sb=2

str=7162

Sb=2

Sb=3

str=7270

Sb=2

Sb=3

str=7182

Sb=2

Sb=3

str=7186

Sb=2

Sb=2

str=7155

Sb=2

Sb=3

str=7156

Sb=2

Sb=3

str=7169

Sb=3

Sb=3

str=7267

Sb=2

Sb=3

str=7175

Sb=2

Sb=2

str=7147

Sb=3

Sb=2

str=7246

Sb=2

Sb=2

str=7169

Sb=2

Sb=3

str=7195

Sb=2

Sb=2

str=7236

 

StringBuffer咋更快或者是相同呢?而且两个SB在多次执行后快了十几倍。而String则一会快点一会慢点。

 

 

而Sun JDK 6.0.30测试结果如下:

Sb=29

Sb=13

str=7783

Sb=3

Sb=1

str=7828

Sb=11

Sb=2

str=7853

Sb=2

Sb=2

str=7758

Sb=2

Sb=2

str=7797

Sb=2

Sb=2

str=7853

Sb=2

Sb=2

str=7876

Sb=3

Sb=2

str=7958

Sb=2

Sb=2

str=7738

Sb=2

Sb=2

str=7692

Sb=2

Sb=2

str=7655

Sb=2

Sb=2

str=7702

Sb=3

Sb=3

str=7675

Sb=2

Sb=2

str=7648

Sb=3

Sb=3

str=7693

Sb=2

Sb=2

str=7772

Sb=2

Sb=2

str=7673

Sb=2

Sb=2

str=7571

Sb=2

Sb=4

str=7817

Sb=3

Sb=2

str=7649

Sb=3

Sb=2

str=7760

Sb=3

Sb=2

str=7724

Sb=2

Sb=2

str=7904

Sb=2

Sb=3

str=7881

Sb=1

Sb=2

str=7884

Sb=3

Sb=2

str=7717

Sb=2

Sb=2

str=7795

Sb=2

Sb=2

str=7566

Sb=2

Sb=2

str=7812

Sb=2

Sb=3

str=8293

Sb=2

Sb=2

str=7770

Sb=2

Sb=2

str=7706

Sb=2

Sb=2

str=7602

Sb=2

Sb=2

str=7704

Sb=2

Sb=2

str=7735

Sb=3

Sb=2

str=7710

Sb=2

Sb=2

str=7717

Sb=2

Sb=2

str=7556

Sb=2

Sb=2

str=7964

Sb=2

Sb=3

str=8210

Sb=3

Sb=2

str=7685

Sb=3

Sb=6

str=7607

Sb=2

Sb=2

str=7721

Sb=2

Sb=2

str=8549

Sb=2

Sb=2

str=7677

Sb=2

Sb=2

str=8081

Sb=2

Sb=2

str=8138

Sb=2

Sb=3

str=7682

Sb=2

Sb=2

str=8205

Sb=2

Sb=2

str=7826

Sb=3

Sb=2

str=7616

Sb=2

Sb=2

str=7750

Sb=2

Sb=2

str=7630

Sb=2

Sb=3

str=8050

Sb=3

Sb=3

str=8066

Sb=2

Sb=2

str=7612

Sb=3

Sb=2

str=7609

Sb=2

Sb=2

str=7749

Sb=2

Sb=2

str=7802

Sb=2

Sb=2

str=7740

Sb=2

Sb=2

str=7683

Sb=3

Sb=2

str=7783

Sb=2

Sb=2

str=7792

Sb=2

Sb=3

str=7680

Sb=2

Sb=3

str=7590

Sb=2

Sb=2

str=7849

Sb=3

Sb=2

 

而Sun JDK基本上都是StringBuilder更快。

 

有时间再测试一下加上各种JVM参数吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值