posts - 241,  comments - 116,  trackbacks - 0
          那么為什么StringBuilder的性能比StringBuffer的高呢?這 則與線程安全有關。如果你讀過《Think in Java》,而且對里面描述HashTable和HashMap區(qū)別的那部分章節(jié)比較熟悉的話,你一定也明白了原因所在。對,就是支持線程同步保證線程安 全而導致性能下降的問題。HashTable是線程安全的,很多方法都是synchronized方法,而HashMap不是線程安全的,但其在單線程程 序中的性能比HashTable要高。StringBuffer和StringBuilder類的區(qū)別也在于此,新引入的StringBuilder類不 是線程安全的,但其在單線程中的性能比StringBuffer高。
          String str="You are nice.";
          str+="I love you so much.";
          如果用StringBuffer類的話,代碼如下:
          StringBuffer str= new StringBuffer("You are nice.");
          str.append("I love you so much.");
          從表面看來String類只用一個加號(+)便完成了字符串的拼接,而StringBuffer類卻要調用一個append()方法,是否實現(xiàn)起來更簡潔,更單純呢?其實不然,讓我們了解一下程序運行內部發(fā)生了哪些事情:Struts與Struts2的區(qū)別

          經(jīng)編譯后程序的bytecode(字節(jié)碼)展示出了實質: 在用String類對象直接拼接時,JVM會創(chuàng)建一個臨時的StringBuffer類對象,并調用其append()方法完成字符串的拼接,這是因為 String類是不可變的,拼接操作不得不使用StringBuffer類(并且--JVM會將"You are nice."和"I love you so much."創(chuàng)建為兩個新的String對象)。之后,再將這個臨時StringBuffer對象轉型為一個String,代價不菲!可見,在這一個簡單 的一次拼接過程中,我們讓程序創(chuàng)建了四個對象:兩個待拼接的String,一個臨時StringBuffer,和最后將StringBuffer轉型成為 的String--它當然不是最初的str了,這個引用的名稱沒變,但它指向了新的String對象。

          而如果直接使用StringBuffer類,程序將只產生兩個對象:最初的StringBuffer和拼接時的String("I love you so much."),也不再需要創(chuàng)建臨時的StringBuffer類對象而后還得將其轉換回String對象。

          可以想象,當我們的字符串要被循環(huán)拼接若干段時,用String類直接操作會帶來多少額外的系統(tǒng)開銷,生成多少無用的臨時StringBuffer對象,并處理多少次無謂的強制類型轉換哪。 
          posted on 2011-07-11 09:43 墻頭草 閱讀(1338) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導航:
           
          人人游戲網(wǎng) 軟件開發(fā)網(wǎng) 貨運專家
          主站蜘蛛池模板: 大新县| 黑山县| 信宜市| 张家口市| 武穴市| 上犹县| 高要市| 弥勒县| 屏东市| 观塘区| 临夏县| 剑阁县| 绥棱县| 鄂尔多斯市| 博白县| 永兴县| 五台县| 大姚县| 静安区| 若尔盖县| 安溪县| 定西市| 高邮市| 囊谦县| 新郑市| 资中县| 凉山| 土默特右旗| 关岭| 延庆县| 芦溪县| 临澧县| 蒙自县| 西盟| 卢龙县| 故城县| 健康| 新闻| 板桥市| 纳雍县| 南安市|