• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            String和StringBuffer的區別

            String對象建立之后不能再改變,如果經常對字符串進行各種各樣的修改,那么使用String來代表字符串的話會引起很大的內存開銷。
            StringBuffer允許修改,不是每個不同的字符串都要生成一個新的對象,兩種類的對象轉換十分容易。

            在我以前的了解中,String是一個final Class, StringBuffer不是。所以對于 String a = "yacht" ,String b = "yacht1" String c = a + b ; 存在一個對象拷貝構造和解析的消耗問題;對于一個StringBuffer來說,StringBuffer sb = new StringBuffer();sb.append("yacht") ; sb.append("yacht1"); 因為StringBuffer是一個可以實例化的類,而且它的內建機制是維護了一個capacity大小的字符數組,所以它的append操作不存在對象的消耗問題,所以我覺得如果存在String連接這種事情,StringBuffer來做會好很多。

                   但事情并不是這么簡單,看下面代碼

                  String a = "yacht1" + "yacht2" + "yacht3" + "yacht4";

                   StringBuffer sb = new StringBuffer(); sb.append("yacht1") ; sb.append("yacht2"); sb.append("yacht3") ; sb.append("yacht4");  String a = sb.toString();

                   如果按照我先前說的看法,紅色的效率肯定比藍色的低,但經過測試不是這樣,為什么?這里,我們需要理解程序過程的兩個時期,一個是編譯時,一個是運行時,在編譯時,編譯器會對你的程序做出優化,所以紅色的String a會被優化成yacht1yacht2yacht3yacht4,而藍色的StringBuffer只會在運行時才處理。所以效率是不一樣的。

                   如果代碼是這樣的:

                   String a ; for(int i = 0; i< 100000;i++){ a += String.valueOf(i) ;}

                   StringBuffer sb = new StringBuffer(); for(int i = 0; i< 100000;i++){ sb.append(i) ;} String a = sb.toString();

                   如果是這種情況的話,紅色的效率就大大不如藍色,區別在哪里,就在于運行時和編譯時的優化問題上!

             

             

            前面看到有人寫String和stringBudffer的區別是前者是不能改寫的,后者是可以改寫的

              我覺得說String的字符串不能改變話是不錯,但是例子要舉好

              看看下面這個簡單的例子:

              首先,

              public class xx {   public static void main(String[] args) {   String s1 = "You are hired!";   String s2 = "You are hired!";   if (s1==s2) {   System.out.println("一個內存空間");   } else {   System.out.println("不是一個內存空間");   }   }   }

              打印的結果是:一個內存空間

              這里==的意義是兩個操作數是否指向同一個對象

              可見s2在不用new創建的情況下會自動檢索到具有相同內容的內存空間中共享,那么既然s1和s2共享了同一個對象

              再看下面的代碼

              public class xx {   public static void main(String[] args) { String s1 = "You are hired!";   String s2 = "You are hired!";   s1 = s1.replace('h','f');   System.out.println(s1);   if (s1==s2) {   System.out.println("一個內存空間");   } else {   System.out.println("不是一個內存空間");   }   }   }

              代碼結果是

              You are fired!

              不是一個內存空間

              可見,String中s1的內容雖然被改寫,但是已經不在是原來第一次分配到的那個內存空間,也就是String類的內容能被改變,但一旦改變系統將為其分配新的內存

              說到與stringBuffer的區別,從根本上來說應該是

              stringBuffer在做字符長度變動的時候將繼續使用原來的內存空間,不新分配.

              而String的長度一旦變動,就如上面的例子一樣,其內部將分配新的內存空間.

            posted on 2009-08-25 22:18 肥仔 閱讀(4731) 評論(0)  編輯 收藏 引用 所屬分類: Web-后臺

            欧美亚洲国产精品久久| 欧洲国产伦久久久久久久| 久久精品人人做人人爽电影| 久久综合精品国产一区二区三区| 香蕉久久久久久狠狠色| 亚洲AV无码久久精品蜜桃| 久久精品国产69国产精品亚洲| 久久精品这里只有精99品| 久久精品国产亚洲av麻豆图片 | 久久久久亚洲AV无码专区体验 | 一级A毛片免费观看久久精品| 亚洲va久久久噜噜噜久久天堂 | 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 亚洲狠狠综合久久| 伊人久久大香线蕉亚洲五月天| 秋霞久久国产精品电影院| 久久人人青草97香蕉| 国内精品伊人久久久久网站| 久久天天躁狠狠躁夜夜网站| 亚洲国产天堂久久久久久| 香蕉久久夜色精品国产小说| 无码超乳爆乳中文字幕久久| 日韩中文久久| 久久影院午夜理论片无码| 久久福利青草精品资源站| 久久天堂AV综合合色蜜桃网| 99久久综合国产精品免费| 久久激情五月丁香伊人| 国产成人AV综合久久| 99久久国产亚洲高清观看2024| 俺来也俺去啦久久综合网| 久久久久人妻一区二区三区vr| 亚洲狠狠婷婷综合久久蜜芽 | 亚洲国产精品久久久久婷婷老年| 久久精品国产乱子伦| 亚洲国产成人乱码精品女人久久久不卡| 久久久久四虎国产精品| 蜜桃麻豆www久久| 久久久久国产精品嫩草影院 | 色综合久久无码中文字幕| 久久亚洲AV成人无码软件|