Java StringBuffer和StringBuilder类

2019-03-28 22:36|来源: 网络

Java StringBuffer和StringBuilder类


当对字符串进行修改的时候,需要使用StringBuffer和StringBuilder类。

和String类不同的是,StringBuffer和StringBuilder类的对象能够被多次的修改,并且不产生新的未使用对象。

StringBuilder类在Java 5中被提出,它和StringBuffer之间的最大不同在于StringBuilder的方法不是线程安全的(不能同步访问)。

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

实例

public class Test{

    public static void main(String args[]){
       StringBuffer sBuffer = new StringBuffer(" test");
       sBuffer.append(" String Buffer");
       System.ou.println(sBuffer);  
   }
}

以上实例编译运行结果如下:

test String Buffer

StringBuffer 方法

以下是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和StringBuffer实现一个通用接口?(Why not have StringBuilder and StringBuffer implement a common interface? [closed])

我没有JSR引用,但从我的exp。 以下是几个原因: 作为StringBuffer的子类的StringBuilder 对于性能原因并不是一个好主意 。 为了让StringBuffer线程安全,你必须掩盖每一个对StringBuilder调用,这是很多开销。 除了上述要点之外, 如果您可以直接访问类的内部部分 ,那么Java可以通过java.util.Collections.synchronized* apis添加java.lang.concurrent ,因此可以进一步优化 。 随着更多直接访问提 ...

JAVA 中Stringbuilder类的方法

如果程序对附加字符串的需求很频繁,不建议使用+来进行字符串的串联,而应该使用java.lang.StringBuilder类,从而使效率大大提高。 1、append 就是将信息追加到当前 StringBuilder 的结尾,例如: StringBuilder sb=new StringBuilder("abc"); sb.append("123"); System.out.println(sb);//输出abc123 2、Insert 就是将字符串或对象插入到当前 StringBuilder 对象 ...

java中教材说String类不能进行修改、删除、替换,要用StringBuffer。

在实用中: String 的改变会改变存放这个数据的物理地址,如果程序中需要频繁得改变某一个String变量的话效率很低 StringBuffer如果改变而导致原来的物理地址不够用的时候,会延伸物理地址,相对String的改变更为方便 我曾经做过类似的东西,不断的往一个String中增加新的字符串,大约一万个,用String要运行1分钟多,用StringBuffer只要1秒 再说,replaceAll()不是对String进行修改,是生成新的String,这样用: String a = "123" ...

为什么StringBuilder有String时?(Why StringBuilder when there is String?)

String不允许附加。 在String上调用的每个方法创建一个新对象并返回它。 这是因为String是不可变的 - 它不能改变它的内部状态。 另一方面StringBuilder是可变的。 当你调用append(..)它改变内部的char数组,而不是创建一个新的字符串对象。 因此,更有效率是: StringBuilder sb = new StringBuilder(); for (int i = 0; i < 500; i ++) { sb.append(i); } 而不是str += ...

何时在Java中使用StringBuilder [duplicate](When to use StringBuilder in Java [duplicate])

如果在循环中使用String连接,这样的话, String s = ""; for (int i = 0; i < 100; i++) { s += ", " + i; } 那么您应该使用StringBuilder (而不是StringBuffer )而不是String ,因为它更快,并且消耗更少的内存。 如果你有一个单一的声明, String s = "1, " + "2, " + "3, " + "4, " ...; 那么可以使用String s,因为编译器会自动使用StringB ...