StringBuffer和StringBuilder的3個區(qū)別
StringBuffer 和 StringBuilder 它們都是可變的字符串,不過它們之間的區(qū)別是 Java 初中級面試出現(xiàn)幾率十分高的一道題。這么簡單的一道題,在面試過程中卻經(jīng)常遇到很多求職者說反,搞不清使用場景的情況。
今天,帶大家徹底搞懂 StringBuffer 和 StringBuilder 的幾個區(qū)別和它們的應用場景,如果你是大牛,請略過,如果你是菜鳥,或者對這兩個不是很清楚,可以學習一下,也可以為年底的面試加油沖刺。
先看看 StringBuffer 和 StringBuilder 的類結(jié)構吧:
其實很簡單,就是繼承了一個抽象的字符串父類:AbstractStringBuilder。下面我們再來看看它們的三個區(qū)別。
區(qū)別1:線程安全
StringBuffer:線程安全,StringBuilder:線程不安全。因為 StringBuffer 的所有公開方法都是 synchronized 修飾的,而 StringBuilder 并沒有 StringBuilder 修飾。
StringBuffer 代碼片段:
- @Override
- public synchronized StringBuffer append(String str) {
- toStringCache = null;
- super.append(str);
- return this;
- }
區(qū)別2:緩沖區(qū)
StringBuffer 代碼片段:
- private transient char[] toStringCache;
- @Override
- public synchronized String toString() {
- if (toStringCache == null) {
- toStringCache = Arrays.copyOfRange(value, 0, count);
- }
- return new String(toStringCache, true);
- }
StringBuilder 代碼片段:
- @Override
- public String toString() {
- // Create a copy, don't share the array
- return new String(value, 0, count);
- }
可以看出,StringBuffer 每次獲取 toString 都會直接使用緩存區(qū)的 toStringCache 值來構造一個字符串。
而 StringBuilder 則每次都需要復制一次字符數(shù)組,再構造一個字符串。
所以,緩存沖這也是對 StringBuffer 的一個優(yōu)化吧,不過 StringBuffer 的這個toString 方法仍然是同步的。
區(qū)別3:性能
既然 StringBuffer 是線程安全的,它的所有公開方法都是同步的,StringBuilder 是沒有對方法加鎖同步的,所以毫無疑問,StringBuilder 的性能要遠大于 StringBuffer。
總結(jié)
所以,StringBuffer 適用于用在多線程操作同一個 StringBuffer 的場景,如果是單線程場合 StringBuilder 更適合。