1️⃣类定义
public final class StringBuffer extends AbstractStringBuilder
implements java.io.Serializable, CharSequence
StringBuffer类跟String类一样定义成final形式,主要是为了“效率”和“安全性”的考虑,若StringBuffer 被继承,由于它的高使用率,可能会降低它的性能。
Serializable:主要是进行序列化的;
AbstractStringBuilder: StringBuffer的父类,StringBuffer很多方法都是直接调用的AbstractStringBuilder的(AbstractStringBuilder类里定义了很多方法,在StringBuffer里是直接通过supper.XXX()调用的)
2️⃣变量
private transient char[] toStringCache;
是StringBuffer中的一个char数组,用来缓存最近一次的toString,每次对字符串进行更改,这个缓存都要作废,在下一次toStrinig后进行重新缓存
3️⃣构造器
/**
* 默认调用的是AbstractStringBuilder(int capacity)的构造器,容量为16
*/
public StringBuffer() {
super(16);
}
/**
* 同无参构造器调用的都是AbstractStringBuilder(int capacity)的构造器
* 容量根据传入的capacity决定;
*/
public StringBuffer(int capacity) {
super(capacity);
}
/**
* 调用的是AbstractStringBuilder(int capacity)的构造器,然后在传入字符串长度的
* 基础上在16进行创建
*/
public StringBuffer(String str) {
super(str.length() + 16);
append(str);
}
4️⃣方法
StringBuffer的常用方法都是直接调用父类AbstractStringBuilder的,这里仅以reverse为例进行讲解
@Override
public synchronized StringBuffer reverse() {
toStringCache = null;
super.reverse();
return this;
}
- 常用的方法基本都是调用的父类的
- 方法声明上多了synchronized修饰符
- 多了一行toStringCache = null(这个toStringCache字段是为了作缓存的).
- return this是和StringBuilder一样的, 都有这段代码.
为了更进一步的说明toStringCache的作用,我们在来看一下toString方法
@Override
public synchronized String toString() {
if (toStringCache == null) {
toStringCache = Arrays.copyOfRange(value, 0, count);
}
return new String(toStringCache, true);
}
这个toStringCache字段是为了作缓存的.
缓存什么呢? 缓存最后一次toString的内容. 当被修改的时候这个cache清空.
也就是说, 如果没被修改, 那么这个toStringCache就是上一次toString的结果.
没被修改的时候, 就可以直接把toStringCache作为new String的参数. 然后把这个String返回就行了.
也就是cache有效的时候, 就不必进行arraycopy的复制操作. cache失效了才进行arraycopy的复制操作.
5️⃣总结
- 构造的大小和16相关. 要么是16, 要么就是加16.(除非使用了定制数组大小的那个构造器, 就是指定多大, 初始数组就是多大了.)
- 实现了toString方法. 内部实现就是每次toString都是new一个String对象.
- 其他方法都是调用的父类的方法. 只是多加了一行return this;
- 方法上加了synchronized修饰符来保证线程安全.
- 有一个toStringCache数组来做缓存