1.String与StrIngBuffer StringBuilder的主要区别在于StrIng是不可变对象,每次对String对象进行修改之后,相对于重新创建一个对象。
String源码解读:
private final char value[];public String() { this.value = "".value; }
不管何种String的构造函数,在初始化之后,其内部value是不可改变
StringBuilder源码
public final class StringBuilder extends AbstractStringBuilder implements java.io.Serializable, CharSequence
可以看出继承了 AbstractStringBuilder 并且实现了序列化接口 java.io.Serializable 和 最底层接口CharSequence
public StringBuilder() { super(16); } AbstractStringBuilder(int capacity) { value = new char[capacity]; }
可以看出其底层维持了一个char[]数组 长度为16
public AbstractStringBuilder append(String str) { if (str == null) return appendNull(); int len = str.length(); ensureCapacityInternal(count + len); str.getChars(0, len, value, count); count += len; return this; }
线程相关内容的 修改其内部的内容 并没有加同步机制
StringBuffer的源码检查
public final class StringBuffer extends AbstractStringBuilder implements java.io.Serializable, CharSequence
可以看出继承的内容类与StringBuilder相同 实现的接口相同
public StringBuffer() { super(16); } AbstractStringBuilder(int capacity) { value = new char[capacity]; }
可以看出底层实现都是char数组 长度为16
@Override public synchronized StringBuffer append(String str) { toStringCache = null; super.append(str); return this; } @Override public synchronized StringBuffer delete(int start, int end) { toStringCache = null; super.delete(start, end); return this; }
内部涉及数据操作部分是又一个同步的过程 是线程安全的
最后涉及扩容机制 StringBuffer StringBuilder正常扩容
最后一点StringBuilder AbstractStringBuilder都是1.5 StringBuffer是1.0