博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
String,StringBuffer与StringBuilder的区别
阅读量:6124 次
发布时间:2019-06-21

本文共 3275 字,大约阅读时间需要 10 分钟。

hot3.png

String 的值是不可变的,每次对String的操作都会生成新的String对象,不仅效率低,而且耗费大量内存空间。

StringBuffer类和String类一样,也用来表示字符串,但是StringBuffer的内部实现方式和String不同,在进行字符串处理时,不生成新的对象,在内存使用上要优于String。
StringBuffer 默认分配16字节长度的缓冲区,当字符串超过该大小时,会自动增加缓冲区长度,而不是生成新的对象。

StringBuffer不像String,只能通过 new 来创建对象,不支持简写方式,例如:

StringBuffer stringBuffer1 = new StringBuffer();  //分配16个字节长度的缓冲区StringBuffer stringBuffer2 = new StringBuffer(512);  //分配512个字节长度的缓冲区StringBuffer stringBuffer3 = new StringBuffer("www.baidu.com");//在缓冲区中存放了字符串,并在后面预留了16个字节长度的空缓冲区

StringBuffer类的主要方法

StringBuffer类中的方法主要偏重于对于字符串的操作,例如追加、插入和删除等,这个也是StringBuffer类和String类的主要区别。实际开发中,如果需要对一个字符串进行频繁的修改,建议使用 StringBuffer。
1)append()方法用于向当前字符串的末尾追加内容,类似于字符串的连接。调用该方法以后,StringBuffer对象的内容也发生改变,例如:

StringBuffer stringBuffer = new StringBuffer(“biancheng100”);stringBuffer.append("111");

则对象stringBuffer的值将变成”biancheng100111”。注意是stringBuffer指向的内容变了,不是stringBuffer的指向变了。

字符串的”+“操作实际上也是先创建一个StringBuffer对象,然后调用append()方法将字符串片段拼接起来,最后调用toString()方法转换为字符串。
这样看来,String的连接操作就比StringBuffer多出了一些附加操作,效率上必然会打折扣。
但是,对于长度较小的字符串,”+“操作更加直观,更具可读性,有些时候可以稍微牺牲一下效率。

2)deleteCharAt()方法用来删除指定位置的字符,并将剩余的字符形成新的字符串。例如:

StringBuffer stringBuffer = new StringBuffer("abcdef");stringBuffer.deleteCharAt(3);

该代码将会删除索引值为3的字符,即”d“字符。

也可以通过delete()方法一次性删除多个字符,例如:

StringBuffer stringBuffer = new StringBuffer("abcdef");stringBuffer.delete(1, 4);

该代码会删除索引值为1~4之间的字符,包括索引值1,但不包括4。

3)insert() 用来在指定位置插入字符串,可以认为是append()的升级版。例如:

StringBuffer stringBuffer = new StringBuffer("abcdef");stringBuffer.insert(3, "xyz");

最后stringBuffer所指向的字符串为 abcdxyzef。

4)setCharAt()方法用来修改指定位置的字符。例如:

StringBuffer stringBuffer = new StringBuffer("abcdef");stringBuffer.setCharAt(3, 'z');

该代码将把索引值为3的字符修改为 z,最后stringBuffer所指向的字符串为 abczef。

以上仅仅是部分常用方法的简单说明,更多方法和解释请查阅API文档。

String和StringBuffer的效率对比

为了更加明显地看出它们的执行效率,下面的代码,将26个英文字母加了10000次。

//用26个英文字母来追加10000次,来比较String与StringBuffer执行效率那个高String fragment ="abcdefghijklmnopqrstuvwxyz";int times =30000;//通过String对象处理long currentTimeStart1 = System.currentTimeMillis();String currentStr ="";for (int i = 0; i < times; i++) {   currentStr+=fragment;}long currentTimeEnd1 = System.currentTimeMillis();System.out.println("String执行消耗时间:"+(currentTimeEnd1-currentTimeStart1)+"ms");//通过StringBuffer对象处理long currentTimeStart2 = System.currentTimeMillis();StringBuffer stringBuffer = new StringBuffer();for (int j = 0; j 

运行结果:

String执行消耗时间:2564msStringBuffer执行消耗时间:-1ms

结论很明显,StringBuffer的执行效率比String快上千倍,这个差异随着叠加次数的增加越来越明显,当叠加次数达到30000次的时候,运行结果为:

String执行消耗时间:12910msStringBuffer执行消耗时间:-2ms

所以,强烈建议在涉及大量字符串操作时使用StringBuffer。

StringBuilder类

StringBuilder类和StringBuffer类功能基本相似,方法也差不多,主要区别在于StringBuffer类的方法是多线程安全的,而StringBuilder不是线程安全的,相比而言,StringBuilder类会略微快一点。
StringBuffer、StringBuilder、String中都实现了CharSequence接口。
CharSequence是一个定义字符串操作的接口,它只包括length()、charAt(int index)、subSequence(int start, int end) 这几个API。
StringBuffer、StringBuilder、String对CharSequence接口的实现过程不一样,如下图所示:

图1  对CharSequence接口的实现,可见,String直接实现了CharSequence接口;StringBuilder 和 StringBuffer都是可变的字符序列,它们都继承于AbstractStringBuilder,实现了CharSequence接口。

总结

线程安全:

StringBuffer:线程安全
StringBuilder:线程不安全

速度:

一般情况下,速度从快到慢为 StringBuilder > StringBuffer > String,当然这是相对的,不是绝对的。

使用环境:

操作少量的数据使用 String;
单线程操作大量数据使用 StringBuilder;
多线程操作大量数据使用 StringBuffer。

**有问必答QQ群:[492698985]**

转载于:https://my.oschina.net/markzhou/blog/684695

你可能感兴趣的文章
WinXp 开机登录密码
查看>>
POJ 1001 Exponentiation
查看>>
HDU 4377 Sub Sequence[串构造]
查看>>
云时代架构阅读笔记之四
查看>>
WEB请求处理一:浏览器请求发起处理
查看>>
Lua学习笔记(8): 元表
查看>>
PHP经典算法题
查看>>
LeetCode 404 Sum of Left Leaves
查看>>
醋泡大蒜有什么功效
查看>>
hdu 5115(2014北京—dp)
查看>>
数据结构中常见的树(BST二叉搜索树、AVL平衡二叉树、RBT红黑树、B-树、B+树、B*树)...
查看>>
PHP读取日志里数据方法理解
查看>>
第五十七篇、AVAssetReader和AVAssetWrite 对视频进行编码
查看>>
Vivado增量式编译
查看>>
一个很好的幻灯片效果的jquery插件--kinMaxShow
查看>>
微信支付签名配置正确,但返回-1,调不出支付界面(有的手机能调起,有的不能)...
查看>>
第二周例行报告
查看>>
vue实现点击展开,点击收起
查看>>
如何使frame能居中显示
查看>>
第k小数
查看>>