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