在《Think in Java》这本书中看到了一章关于字符串的性能说明,Stringl对象每执行一次“+”操作都会产生一个新的String对象,StringBuilder执行连接操作只有一个对象,然后做了一些关于这个方面的测试。
思路如下:
1.通过编写Java程序对String类对象和StringBuilder执行分别执行N次String += String 和StringBuilder.append()操作,分别获取执行相同次“+”操作的时间,然后用StringBuilder执行的时间比上String执行的时间。
2.通过shell脚本重复执行100次Java程序,获取结果。测试环境:操作系统Centos-6.8 , 虚拟机,memer:512M
Java程序:
public class TestString {
//测试String类型的重载运行所发费的时间
public long testString(int size){
long start = System.currentTimeMillis();
String str = "String";
for(int i=0; i < size; i++){
str += i;
}
long end = System.currentTimeMillis();
long paytime = end - start;
}
//测试StringBuilder进行append所发费的时间
public long testStringBuilder(int size){
long start = System.currentTimeMillis();
StringBuilder sb = new StringBuilder("StringBuilder");
for(int i=0; i < size; i++){
sb.append(i);
}
long end = System.currentTimeMillis();
long paytime = end - start;
return paytime;
}
//获得StringBuilder和String的速度比
public long getSpeedb(int size){
long stringbuilder = testStringBuilder(size);
long string = testString(size);
long b = stringbuilder==0?string:string/stringbuilder; return b;
}
public static void main(String[] args){
TestString ts = new TestString();
//测试的getSpeedb中的参数是执行多少次“+”,测试分别取得1000,10000,100000
long b = ts.getSpeedb(1000);
System.out.println("String / StringBuilder : "+b);
}
}
Shell脚本:
#!/bin/bash
javac TestString.java
for i in `seq 100`
do
echo `java TestString` >> result.txt
done
本人测试结果:
程序每种运行100次
执行1000次连接:String/StringBuilder 范围在8~11之间
执行10000次连接:String/StringBuilder 范围在14~26之间
执行100000次连接:String/StringBuilder 范围在496~1188之间