import java.util.Date;
import java.util.UUID;
/**
* 测试String,StringBuilder性能,判断什么时候改用String,什么时候该用StringBuilder
* 测试结果
* String 拼接测试,测试长度10000,测试字符串数组长度30,完成时间721
StringBuilder 拼接测试,测试长度10000,测试字符串数组长度30,完成时间315
String 拼接测试,测试长度10000,测试字符串数组长度10,完成时间301
StringBuilder 拼接测试,测试长度10000,测试字符串数组长度10,完成时间124
String 拼接测试,测试长度10000,测试字符串数组长度5,完成时间237
StringBuilder 拼接测试,测试长度10000,测试字符串数组长度5,完成时间68
String 拼接测试,测试长度10000,测试字符串数组长度50,完成时间1169
StringBuilder 拼接测试,测试长度10000,测试字符串数组长度50,完成时间504
String 拼接测试,测试长度10000,测试字符串数组长度2,完成时间188
StringBuilder 拼接测试,测试长度10000,测试字符串数组长度2,完成时间31
String 拼接测试,测试长度20000,测试字符串数组长度2,完成时间253
StringBuilder 拼接测试,测试长度20000,测试字符串数组长度2,完成时间59
*
* 这几组至少是2倍以上的时间差距,
* 当然小范围的拼接几乎时间都是可以忽略不计的,但是你如果作为工具类或者大范围的拼接最好还是用StringBuilder,哪怕只是拼接两个字符串
* @author JueYue
*
*/
public class StringTest {
public static void main(String[] args) {
int testLength = 10000;
String[] arr = new String[2];
Date start = new Date();
String str = "";
for (int i = 0; i < testLength; i++) {
str = "";
for (int j = 0; j < arr.length; j++) {
str += UUID.randomUUID().toString();
}
}
System.out.println("String 拼接测试,测试长度" + testLength + ",测试字符串数组长度"
+ arr.length + ",完成时间"
+ (new Date().getTime() - start.getTime()));
start = new Date();
StringBuilder sb;
for (int i = 0; i < testLength; i++) {
sb = new StringBuilder();
for (int j = 0; j < arr.length; j++) {
sb.append(UUID.randomUUID().toString());
}
}
System.out.println("StringBuilder 拼接测试,测试长度" + testLength + ",测试字符串数组长度"
+ arr.length + ",完成时间"
+ (new Date().getTime() - start.getTime()));
}
}