<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)  編輯  收藏 所屬分類: 基礎知識

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲综合激情五月色一区| heyzo亚洲精品日韩| 亚洲大片免费观看| 久久久久久精品免费看SSS| 8x8×在线永久免费视频| 亚洲精品在线免费观看视频| 1000部拍拍拍18勿入免费视频下载| 91热久久免费精品99| 精品久久8x国产免费观看| 美女视频黄的全免费视频| 毛片a级毛片免费观看品善网| 青青青国产在线观看免费网站| 中文字幕av无码无卡免费| 性xxxx视频播放免费| 国产免费69成人精品视频| 亚洲AⅤ视频一区二区三区| 久久亚洲色一区二区三区| 精品久久久久久亚洲| 亚洲色欲色欲综合网站| 亚洲一区中文字幕在线观看| 国产午夜亚洲精品| 国产亚洲情侣久久精品| 亚洲一区二区三区免费| 少妇太爽了在线观看免费视频| 黄色网址免费大全| 大学生高清一级毛片免费| 四虎永久免费观看| 亚洲精品乱码久久久久久按摩 | 91精品国产免费久久国语麻豆| 日本免费网站视频www区| 成人毛片18岁女人毛片免费看| 无码国模国产在线观看免费| 国产精品亚洲二区在线观看| 亚洲AV无码一区二区二三区软件 | 亚洲AV成人精品日韩一区18p| 亚洲五月综合缴情在线观看| 久久久久亚洲AV无码观看| 亚洲精品国产高清在线观看| 久久国产乱子伦精品免费午夜| 日韩在线不卡免费视频一区| 好男人视频社区精品免费|