Java 常用API——StringBuffer和StringBuilder

StringBuffer和StringBuilder类

对象能够被多次的修改,并且不产生新的未使用对象

StringBuffer之间的最大不同在于StringBuilder的方法不是线程安全的(不能同步访问)

StringBuilder相较于StringBuffer有速度优势,所以多数情况下建议使用StringBuilder类。然而在应用程序要求线程安全的情况下,则必须使用StringBuffer类

 

1、public StringBuffer append(String s)

将指定的字符串追加到此字符序列。

2、public StringBuffer reverse()

将此字符序列用其反转形式取代。

3、public delete(int start, int end)

移除此序列的子字符串中的字符。

4、public insert(int offset, int i)

将int参数的字符串表示形式插入此序列中。

5、replace(int start, int end, String str)

使用给定String中的字符替换此序列的子字符串中的字符。

下面的列表里的方法和String类的方法类似:

序号方法描述

1、int capacity()

返回当前容量。

2、char charAt(int index)

返回此序列中指定索引处的char值。

3、void ensureCapacity(int minimumCapacity)

确保容量至少等于指定的最小值。

4、、void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)

将字符从此序列复制到目标字符数组dst。

5、int indexOf(String str)

返回第一次出现的指定子字符串在该字符串中的索引。

6、int indexOf(String str, int fromIndex)

从指定的索引处开始,返回第一次出现的指定子字符串在该字符串中的索引。

7、int lastIndexOf(String str)

返回最右边出现的指定子字符串在此字符串中的索引。

8、int lastIndexOf(String str, int fromIndex)

返回最后一次出现的指定子字符串在此字符串中的索引。

9、int length()

返回长度(字符数)。

10、void setCharAt(int index, char ch)

将给定索引处的字符设置为ch。

11、void setLength(int newLength)

设置字符序列的长度。

12、CharSequence subSequence(int start, int end)

返回一个新的字符序列,该字符序列是此序列的子序列。

13、String substring(int start)

返回一个新的String,它包含此字符序列当前所包含的字符子序列。

14、String substring(int start, int end)

返回一个新的String,它包含此序列当前所包含的字符子序列。

15、String toString()

返回此序列中数据的字符串表示形式。

 

 

在处理字符串拼接的时候,使用StringBuilder的效率会比硬拼接字符串高很多。

  static void Main(string[] args)
        {
            string str1 = string.Empty;
            Stopwatch sw1 = new Stopwatch();
            sw1.Start();
            for (int i = 0; i < 10000; i++)
            {
                str1 = str1 + i.ToString();
            }
            sw1.Stop();
            Console.WriteLine("拼接字符串所耗费时间为:" + sw1.ElapsedMilliseconds + "毫秒");
            StringBuilder str2 = new StringBuilder(10000);
            Stopwatch sw2 = new Stopwatch();
            sw2.Start();
            for (int i = 0; i < 10000; i++)
            {
                str2.Append(i.ToString());
            }
            sw2.Stop();
            Console.WriteLine("使用StringBuilder所耗费时间为:" + sw2.ElapsedMilliseconds + "毫秒");
            Console.ReadKey();
        }

 

1

string类型的特别之处在于我们可以像使用值类型那样使用string类型,而实际上string是引用类型。既然是引用类型,CLR就会把string类型保存在托管堆上。当我们使用str1 = str1 + i.ToString();进行拼接,由于string类型的恒定性,不会改变str1在内存中的地址,而是在托管堆上创建了另外一个字符串对象。如此,拼接10000次,就创建了10000个string类型对象,效率难免低下。

 

而StringBuilder会在内存中开辟一块连续的内存,当增加字符串实际上是针对同一块内存的修改,所以效率更高。  

 

当然,到底使用硬拼接字符串,还是使用StringBuilder,不是绝对的,要看情况。当拼接字符串很少的情况下,当然直接硬拼接字符串就行了。    

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值