首頁  >  文章  >  Java  >  JAVA中StringBuffer與String的區別解析

JAVA中StringBuffer與String的區別解析

高洛峰
高洛峰原創
2017-01-22 09:36:141463瀏覽

看到這個講解的不錯,所以轉一下

在java中有3個類別來負責字符的操作。

1.Character 是進行單一字元操作的,

2.String 對一串字元進行操作,不可變類別。

3.StringBuffer 也是對一串字元進行操作,是可變類別。

String:
    是物件不是原始型別.
    為不可變物件,一旦建立,就不能修改它的值.
    對於已經存在的String物件的修改都是重新建立一個新的物件,然後把新的物件值保存進去.
String 是final類別,即不能被繼承.

StringBuffer:
    是可變物件,當對他進行修改的時候不會像String那樣重新建立物件
    它只能透過建構函數來建立 它只能透過建構函數來建立,
    StringBuffer sb = new StringBuffer();
注意:不能透過賦值符號對它進行付值. 
sb = "welcome to here!";//error
物件被建立以後空間,在記憶體中就會分配記憶體,並初始保存一個null.向StringBuffer賦值的時候可以通過它的append()方法.
sb.append("hello");

字符串連接操作中StringBuffer的效率要比String高:

String str = new String("welcome to ");
str += "here";
的處理步驟其實是透過建立一個StringBuffer,然後呼叫append(),最後
再將StringBuffer toSting();
這樣的話String的連接操作就比StringBuffer多出了一些附加操作,當然效率上要打折扣.

並且由於String 物件是不可變物件,每次操作Sting 都會重新建立新的物件來保存新的值.
這樣原來的物件就沒用了,就要被垃圾回收.這也是要影響性能的.

看看以下代碼:
將26個英文字母重複加了5000次,

        String tempstr = "abcdefghijklmnopqrstuvwxyz";
        int times = 5000;
        long lstart1 = System.currentTimeMillis();
        String str = "";
        for (int i = 0; i < times; i++) {
            str += tempstr;
        }
        long lend1 = System.currentTimeMillis();
        long time = (lend1 - lstart1);
        System.out.println(time);
可惜我的計算機不是超級計算機,得到的結果每次不一定一樣一般為46687左右。
也就是46秒。

我們再看以下程式碼

        String tempstr = "abcdefghijklmnopqrstuvwxyz";
        int times = 5000;
        long lstart2 = System.currentTimeMillis();
        StringBuffer sb = new StringBuffer();
        for (int i = 0; i < times; i++) {
            sb.append(tempstr);
        }
        long lend2 = System.currentTimeMillis();
        long time2 = (lend2 - lstart2);
        System.out.println(time2);

得到的結果為 16 有時還是 0
所以結論很明顯,StringBuffer 的速度幾乎是String 上萬倍。當然這個數據不是很準確。因為循環的次數在100000次的時候,差異更大。不信你試試


如果還是不能夠明白:

1)String的聯合+方法與StringBuff的append方法的區別:

String的+運算符在進行字串運算時,首先將字串運算字串物件轉換為StringBuff 類型,呼叫其append方法,最後將產生的StringBuff 物件透過其toString 方法轉換為String類型的字串,所以其效率要低。

但是在可讀性上,還是String的連接運算子要高。

2)StringBuff是線程安全的

String是線程是非安全的

3)String是不可以修改的字串對象,而StringBuff是可以修改的。

public static boolean fileCopy(String srcStr, String destStr) {
File srcFile = null;
File destFile = null;
Reader reader = null;
Writer writer = null;
boolean flag = false;
try {
srcFile = new File(srcStr);
if (!srcFile.exists()) {
System.out.println(“源文件不存在”);
System.exit(0);
} else {
reader = new FileReader(srcFile);
}
destFile = new File(destStr);
writer = new FileWriter(destFile);
char[] buff = new char[1024];
int len;
String str = “”;
StringBuffer sbuff = new StringBuffer();
while ((len = reader.read(buff)) != -1) {
//        str += new String(buff, 0, len);
sbuff.append(new String(buff,0,len));
}
//      writer.write(str.toCharArray());
writer.write(sbuff.toString().toCharArray());
flag = true;
writer.flush();
reader.close();
writer.close();
} catch (IOException e) {
System.out.println(“文件拷贝异常:= ” + e.getMessage());
}
return flag;
}

更多JAVA中StringBuffer與String的區別解析相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn