读书人

StringBuilderStringBuffer与Stri

发布时间: 2012-12-18 12:43:41 作者: rapoo

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参数吧。

读书人网 >编程

热点推荐