string,stringbuffer, stringbuilder 的差別
string和stringbuffer的差別,網上資料可以說是數不勝數,但是看到這篇文章,感覺裡面做的小例子很有代表性,是以轉一下,并自己做了一點總結。
在java中有3個類來負責字元的操作。
1.character 是進行單個字元操作的,
2.string 對一串字元進行操作。不可變類。
3.stringbuffer 也是對一串字元進行操作,但是可變類。
string:
是對象不是原始類型.
為不可變對象,一旦被建立,就不能修改它的值.
對于已經存在的string對象的修改都是重新建立一個新的對象,然後把新的值儲存進去.
string 是final類,即不能被繼承.
stringbuffer:
是一個可變對象,當對他進行修改的時候不會像string那樣重建立立對象
它隻能通過構造函數來建立,
stringbuffer sb = new stringbuffer();
note:不能通過付值符号對他進行付值.
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次,
1
2
3
4
5
6
7
8
9
10
11
<code>string tempstr =</code><code>"abcdefghijklmnopqrstuvwxyz"</code><code>;</code>
<code>int</code> <code>times =</code><code>5000</code><code>;</code>
<code>long</code> <code>lstart1 = system.currenttimemillis();</code>
<code>string str =</code><code>""</code><code>;</code>
<code>for</code> <code>(</code><code>int</code> <code>i =</code><code>0</code><code>; i < times; i++) {</code>
<code>str += tempstr;</code>
<code>}</code>
<code>long</code> <code>lend1 = system.currenttimemillis();</code>
<code>long</code> <code>time = (lend1 - lstart1);</code>
<code>system.out.println(time);</code>
可惜我的計算機不是超級計算機,得到的結果每次不一定一樣一般為 46687左右。
也就是46秒。
我們再看看以下代碼
<code>long</code> <code>lstart2 = system.currenttimemillis();</code>
<code>stringbuffer sb =</code><code>new</code> <code>stringbuffer();</code>
<code>sb.append(tempstr);</code>
<code>long</code> <code>lend2 = system.currenttimemillis();</code>
<code>long</code> <code>time2 = (lend2 - lstart2);</code>
<code>system.out.println(time2);</code>
得到的結果為 16 有時還是 0
是以結論很明顯,stringbuffer 的速度幾乎是string 上萬倍。當然這個資料不是很準确。因為循環的次數在100000次的時候,差異更大。不信你試試。
根據上面所說:
是以str += “here”;可以等同于
stringbuffer sb = new stringbuffer(str);
sb.append(“here”);
str = sb.tostring();
是以上面直接利用”+”來連接配接string的代碼可以基本等同于以下代碼
12
13
<code>stringbuffer sb =</code><code>new</code> <code>stringbuffer(str);</code>
<code>str = sb.tostring();</code>
平均執行時間為46922左右,也就是46秒。
總結: 如果在程式中需要對字元串進行頻繁的修改連接配接操作的話.使用stringbuffer性能會更高