String、StringBuffer、StringBuilder效率比较

String
Java中的String对象是final的,即 String 对象被创建之后就无法再对其进行修改。也就是说,尽管 String 类提供了替换(replace)、截取子串(subString)等方法,但这些方法都不是直接对原始的 String 对象进行操作,其操作结果会生成一个全新的字符串对象。当我们使用 + 来连接两个 String 对象的时候,该操作同样是创建出一个全新的字符串对象。

示例代码:

String str = “aaabbbcccddd”;
String newStr = str.replace(‘a’, ‘A’);
System.out.println(newStr);

说明:
替换之后的结果是生成了一个全新的字符串对象:newStr 。

StringBuffer
StringBuffer类是对String类的一个补充,它用来表示内容可变的字符串,并提供了修改底层字符串的方法。StringBuffer类从 JDK 1.0 就已经提供。

该类是线程安全的。

示例代码:

StringBuffer sb = new StringBuffer(“aaabbbcccddd”);
sb.replace(0, 3, “AAA”);
System.out.println(sb.toString());

说明:
直接在 StringBuffer对象上进行操作。

API文档链接:http://download.oracle.com/javase/1.5.0/docs/api/java/lang/StringBuffer.html

StringBuilder
我们可以将 StringBuilder 类看做是对 StringBuffer 的进一步补充。StringBuilder 类也表示内容可变的字符串,并且该类与 StringBuffer 有着相同的操作界面,唯一的区别就是 StringBuilder 类不是线程安全的。

JDK 1.5 开始提供 StringBuilder 类。

API文档链接:http://download.oracle.com/javase/1.5.0/docs/api/java/lang/StringBuilder.html

效率的比较:


String str = “”;
long beginTime = System.currentTimeMillis();

for (int i = 0; i < 999999; i++){ str = str + i; } long endTime = System.currentTimeMillis(); System.out.println("执行时间:" + (endTime - beginTime));

运行时间太长了,没有等到程序运行结束就被我直接终止了。


StringBuffer buffer = new StringBuffer(“”);
long beginTime = System.currentTimeMillis();
for (int i = 0; i < 999999; i++){ buffer.append(i); } long endTime = System.currentTimeMillis(); System.out.println("执行时间:" + (endTime - beginTime));

输出:


执行时间:250


StringBuilder builder = new StringBuilder(“”);
long beginTime = System.currentTimeMillis();
for (int i = 0; i < 99999; i++){ builder.append(i); } long endTime = System.currentTimeMillis(); System.out.println("执行时间:" + (endTime - beginTime));

输出:


执行时间:188

在数量级相对较小的时候,StringBuffer和StringBuilder的区别不大,只有当数量级相对较大的时候才能体会到他们两个之间的效率差别。

StringBuffer为了做到线程安全,牺牲一定的效率是必然的。

在java中,String + StringBuffer + StringBuilder 基本涵盖了java字符串操作的所有方面,掌握好这三个工具类,基本的字符串处理可以无忧了。

此条目发表在java/j2ee分类目录,贴了, , 标签。将固定链接加入收藏夹。

发表评论

您的电子邮箱地址不会被公开。

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据