自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JAVA之中的String與StringBuffer的區(qū)別

開發(fā) 后端
本文講述了String和StringBuffer的區(qū)別,其中的例子比較具有代表性,并且作者對其進行了簡單的總結(jié),并得出結(jié)論:如果在程序中需要對字符串進行頻繁的修改連接操作的話.使用StringBuffer性能會更高。

String和StringBuffer的區(qū)別,網(wǎng)上資料可以說是數(shù)不勝數(shù),但是看到這篇文章,感覺里面做的小例子很有代表性,所以轉(zhuǎn)一下,并自己做了一點總結(jié)。

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

1.Character 是進行單個字符操作的。

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

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

String:
是對象不是原始類型.
為不可變對象,一旦被創(chuàng)建,就不能修改它的值.
對于已經(jīng)存在的String對象的修改都是重新創(chuàng)建一個新的對象,然后把新的值保存進去.
String 是final類,即不能被繼承.

StringBuffer:
是一個可變對象,當對他進行修改的時候不會像String那樣重新建立對象
它只能通過構(gòu)造函數(shù)來建立,
StringBuffer sb = new StringBuffer();
note:不能通過付值符號對他進行付值.
sb = "welcome to here!";//error
對象被建立以后,在內(nèi)存中就會分配內(nèi)存空間,并初始保存一個null.向StringBuffer
中付值的時候可以通過它的append方法.
sb.append("hello");

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

String str = new String("welcome to ");
str += "here";
的處理步驟實際上是通過建立一個StringBuffer,讓侯調(diào)用append(),最后
再將StringBuffer toSting();
這樣的話String的連接操作就比StringBuffer多出了一些附加操作,當然效率上要打折扣.

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

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

  1. String tempstr = "abcdefghijklmnopqrstuvwxyz";   
  2.  int times = 5000;   
  3.  long lstart1 = System.currentTimeMillis();   
  4.  String str = "";   
  5.  for (int i = 0; i < times; i++) {   
  6.      str += tempstr;   
  7.  }   
  8.  long lend1 = System.currentTimeMillis();   
  9.  long time = (lend1 - lstart1);   
  10.  System.out.println(time); 

可惜我的計算機不是超級計算機,得到的結(jié)果每次不一定一樣一般為 46687左右,也就是46秒。
我們再看看以下代碼:

  1. String tempstr = "abcdefghijklmnopqrstuvwxyz";   
  2. int times = 5000;   
  3. long lstart2 = System.currentTimeMillis();   
  4. StringBuffer sb = new StringBuffer();   
  5. for (int i = 0; i < times; i++) {   
  6.     sb.append(tempstr);   
  7. }   
  8. long lend2 = System.currentTimeMillis();   
  9. long time2 = (lend2 - lstart2);   
  10. System.out.println(time2); 

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

 

根據(jù)上面所說:

str += "here";的處理步驟實際上是通過建立一個StringBuffer,讓侯調(diào)用append(),最后再將StringBuffer toSting();所以str += "here";可以等同于:

  1. StringBuffer sb = new StringBuffer(str);  
  2.  
  3. sb.append("here");  
  4.  
  5. str = sb.toString(); 

所以上面直接利用"+"來連接String的代碼可以基本等同于以下代碼:

  1. String tempstr = "abcdefghijklmnopqrstuvwxyz";   
  2. int times = 5000;   
  3. long lstart2 = System.currentTimeMillis();   
  4. String str = "";   
  5. for (int i = 0; i < times; i++) {   
  6.     StringBuffer sb = new StringBuffer(str);   
  7.     sb.append(tempstr);   
  8.     str = sb.toString();   
  9. }   
  10. long lend2 = System.currentTimeMillis();   
  11. long time2 = (lend2 - lstart2);   
  12. System.out.println(time2); 

平均執(zhí)行時間為46922左右,也就是46秒。

總結(jié): 如果在程序中需要對字符串進行頻繁的修改連接操作的話.使用StringBuffer性能會更高

【編輯推薦】

  1. Java程序開發(fā)中的簡單內(nèi)存分析
  2. 2009年十大Java技術解決方案
  3. 2008最值得學習的五種JAVA技術
  4. Java 7路線圖更新 未包含閉包特性
  5. Java 7.0中值得期待的新功能預覽
責任編輯:仲衡 來源: CSDN博客
相關推薦

2020-11-13 05:56:01

StringBuffeStringBuild字符串

2012-06-17 13:08:54

Stringstringbuldestringbuffe

2009-06-12 09:12:27

VectorJava

2024-03-07 16:12:46

Java字符串線程

2011-06-01 14:01:45

JavaString

2024-03-07 13:30:44

Java對象true

2021-03-15 08:38:42

StringBuffeJava基礎Java開發(fā)

2009-08-24 17:45:39

Java與C#的區(qū)別

2011-11-29 09:14:48

JavaError異常

2009-12-24 17:16:23

Ado Oledb

2010-09-25 11:23:15

Java內(nèi)存泄露

2013-01-09 08:59:13

20122013iOS

2017-07-20 16:02:27

Python編程

2009-06-15 14:16:17

JBoss與Tomca

2009-02-16 09:25:43

EJBJavaBeanWebSphere

2013-06-14 10:45:15

NFVSDNOpenFlow

2009-08-21 09:28:23

this與$(this

2009-07-06 17:08:53

JDBC與ODBC的區(qū)

2021-07-02 06:54:45

GoJavachannel

2009-03-02 19:49:38

Mesh網(wǎng)絡Wi-FiWLAN
點贊
收藏

51CTO技術棧公眾號