1.初始化
StringBuffer和StringBuilder就是所谓的可变字符串类,共四个构造方法:
StringBuffer()
public StringBuffer(int paramInt)
public StringBuffer(String paramString)
public StringBuffer(CharSequence paramCharSequence)
看其源码可知,使用StringBuffer时,默认开辟16个字符的长度空间,使用public StringBuffer(int paramInt)时开辟指定大小的空间,使用public StringBuffer(String paramString)时,开辟paramString.length+16大小的空间。都是调用父类的构造器super()来开辟内存。这方面StringBuffer和StringBuilder都一样,且都实现AbstractStringBuilder类。
2.主要方法
StringBuilder和StringBuffer几乎没有什么区别,基本都是调用父类的各个方法,但一个重要的区别是StringBuffer是线程安全的,内部的大多数方法前面都有关键字synchronized,这样就会有一定的性能消耗,即比StringBuilder耗时,StringBuilder是非线程安全的,效率高一点。
常用方法有:
public synchronized int length()
public synchronized int capacity()
这二者都是获取字符串的长度,但length()获取的是当前字符串的长度,而capacity()获取的是当前缓冲区的大小。例如:
StringBuffer sb = new StringBuffer();
System.out.println(sb.length());
System.out.println(sb.capacity());
输出:
0
16
StringBuffer sb = new StringBuffer("hello");
System.out.println(sb.length());
System.out.println(sb.capacity());
输出:
5
21
因为默认分配16个字符大小的空间,所以会输出以上结果。
public boolean equals(Object paramObject)
例子:
StringBuffer sb = new StringBuffer("hello");
StringBuffer sb2 = new StringBuffer("hello");
System.out.println(sb.equals(sb2));
结果输出false!原因是之前说的String类重写了Object的equals()方法,所以在String类中的比较只需要看内容是否相等即可,但是StringBuffer没有重写equals(),此处的equals()仍然是调用Object类的,所以,调用StringBuffer类的equals(),只有地址和内容都相等的字符串,结果才会返回true。
另外,StringBuffer有一系列追加、插入、删除字符串的方法。首先append(),就是在原来字符串后面直接追加一个新的串,和String类相比有明显的好处:
String类在追加时,源字符串不变(这就是为什么说String是不可变的字符串类型),和新串连接后,重新开辟一个内存,这样就会造成每次连接以后新串都会让之前的串报废,因此也造成了不可避免的内存泄露。
public synchronized void trimToSize() 该方法用于将多余的缓冲区空间释放出来。
StringBuffer sb = new StringBuffer("hello world");
System.out.println("length: " + sb.length());
System.out.println("capacity: " + sb.capacity());
sb.trimToSize();
System.out.println("capacity afer trimToSize(): " + sb.capacity());
输出:
length: 12
capacity: 28
capacity afer trimToSize(): 12
StringBuffer类还有很多方法,关于字符查找、截取、替换方面的方法,有兴趣的可去研究源码。