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