码迷,mamicode.com
首页 > 其他好文 > 详细

String,StringBuilder性能对比

时间:2014-12-16 13:28:27      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:java   string   测试   stringbuilder   

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()));
}


}

String,StringBuilder性能对比

标签:java   string   测试   stringbuilder   

原文地址:http://blog.csdn.net/qjueyue/article/details/41958869

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!