651
技術社區[雲棲]
String,StringBuffer, StringBuilder 的區別
在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
|
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秒。
我們再看看以下代碼
1
2
3
4
5
6
7
8
9
10
11
|
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次的時候,差異更大。不信你試試。
根據上麵所說:
str += “here”;
的處理步驟實際上是通過建立一個StringBuffer,讓侯調用append(),最後
再將StringBuffer toSting();
所以str += “here”;可以等同於
StringBuffer sb = new StringBuffer(str);
sb.append(“here”);
str = sb.toString();
所以上麵直接利用”+”來連接String的代碼可以基本等同於以下代碼
1
2
3
4
5
6
7
8
9
10
11
12
13
|
String tempstr = "abcdefghijklmnopqrstuvwxyz" ;
int times = 5000 ;
long lstart2 = System.currentTimeMillis();
String str = "" ;
for ( int i = 0 ; i < times; i++) {
StringBuffer sb = new StringBuffer(str);
sb.append(tempstr); str = sb.toString(); } long lend2 = System.currentTimeMillis();
long time2 = (lend2 - lstart2);
System.out.println(time2); |
平均執行時間為46922左右,也就是46秒。
總結: 如果在程序中需要對字符串進行頻繁的修改連接操作的話.使用StringBuffer性能會更高
最後更新:2017-04-02 06:51:37
上一篇:
C++ 智能指針
下一篇:
magento開始辦官方培訓班了,課程價格真給力啊
開發那點事係列三 - 由XML解析引起的API設計思考
不要重複發明輪子:C++重用的5重境界(1)——代碼重用
OpenVAS:Kali Linux 中的漏洞評估工具
橫豎屏切換時候Activity的生命周期
阿裏雲個人免費套餐6個月,每天共享一枚,先到先得!
Main方法傳遞參數執行動態程序
漏洞預警:WordPress 儲存型 XSS 漏洞
絕對精彩的馬字成語接龍40龍
連載:麵向對象葵花寶典:思想、技巧與實踐(23) - 領域建模三字經
政府安全資訊精選 2017年第十二期 中國網絡安全漏洞披露平均效率遠超美國; 美國美國國土安全部發布指令,要求聯邦機構強化Web和電子郵件安全