Java中String和StringBuilder性能比较

     在《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之间

你可能感兴趣的:(Java)