对于字符串操作,类似于“+”和“+=”的运算符应该尽量少用。其次,String的concat()方法效率远远高于“+”和“+=”运算符,但是又远远低于StringBuilder类。
Note: 在无需考虑线程安全的情况下,使用性能相对较好的StringBuilder,但是若系统有线程安全要求,只能选择StringBuffer。String尽量不用!
public class BuilderorBuffer {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
noCapacity();
hasCapacity();
}
public static void noCapacity(){
StringBuilder sbuilder = new StringBuilder();
long start = System.currentTimeMillis();
for(int i=0;i<5000000;i++){
sbuilder.append(i);
}
System.out.println("noCapacity,StringBuilder elapsed:" + (System.currentTimeMillis() - start));
StringBuffer sbuffer = new StringBuffer();
long start2 = System.currentTimeMillis();
for(int i=0;i<5000000;i++){
sbuffer.append(i);
}
System.out.println("noCapacity,StringBuffer elapsed:" + (System.currentTimeMillis() - start2));
}
public static void hasCapacity(){
StringBuilder sbuilder = new StringBuilder(50000000);
long start = System.currentTimeMillis();
for(int i=0;i<5000000;i++){
sbuilder.append(i);
}
System.out.println("hasCapacity,StringBuilder elapsed:" + (System.currentTimeMillis() - start));
StringBuffer sbuffer = new StringBuffer(50000000);
long start2 = System.currentTimeMillis();
for(int i=0;i<5000000;i++){
sbuffer.append(i);
}
System.out.println("hasCapacity,StringBuffer elapsed:" + (System.currentTimeMillis() - start2));
}
}
分别对StringBuilder和StringBuffer,在不指定容量和指定容量两个情况下,append五十万的结果(单位ms):
noCapacity,StringBuilder elapsed:600
noCapacity,StringBuffer elapsed:1395
hasCapacity,StringBuilder elapsed:275
hasCapacity,StringBuffer elapsed:708
ps.原以为在大数据时代,机器学习算法需要参数调优,原来在这里就已经出现参数调优了。