<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-9  評論-0  文章-0  trackbacks-0

    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次,

            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次的時候,差異更大。不信你試試。

     

    根據上面所說:

    str += "here";
    的處理步驟實際上是通過建立一個StringBuffer,讓侯調用append(),最后
    再將StringBuffer toSting();

    所以str += "here";可以等同于

    StringBuffer sb = new StringBuffer(str);

    sb.append("here");

    str = sb.toString();

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

            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性能會更高

    posted on 2010-01-21 17:22 AndyFish 閱讀(149) 評論(0)  編輯  收藏 所屬分類: 基礎知識

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


    網站導航:
     
    主站蜘蛛池模板: 国产白丝无码免费视频| a毛片久久免费观看| 18禁网站免费无遮挡无码中文| 亚洲国产精品一区二区成人片国内 | 亚洲成在人天堂在线| 免费久久人人爽人人爽av| 亚洲桃色AV无码| 97国免费在线视频| 亚洲AV午夜成人影院老师机影院| 男人都懂www深夜免费网站| 亚洲gv猛男gv无码男同短文| 99精品视频在线视频免费观看| 亚洲第一二三四区| 成人免费无码大片a毛片| 国产成人人综合亚洲欧美丁香花| 日本xxwwxxww在线视频免费| 日韩国产精品亚洲а∨天堂免| www.亚洲一区| 永久免费av无码网站yy| 内射干少妇亚洲69XXX| 91在线视频免费看| 日本一区二区三区免费高清在线| 中文字幕专区在线亚洲| 久久国产乱子精品免费女| 亚洲高清视频免费| 免费无码看av的网站| 一道本不卡免费视频| 亚洲人成亚洲精品| 在线免费观看视频你懂的| 欧洲乱码伦视频免费国产 | 成全视频免费高清| 一区二区三区免费看| 亚洲另类激情综合偷自拍| 最新猫咪www免费人成| 免费人成大片在线观看播放| 国产V亚洲V天堂无码久久久| 免费观看AV片在线播放| 免费无码又爽又黄又刺激网站 | 任你躁在线精品免费| 在线观看亚洲AV日韩A∨| 亚洲人成无码www久久久|