Sung in Blog

                     一些技術文章 & 一些生活雜碎
          問題:在String對象中有個構造函數是直接接受StringBuffer的。程序如下:

          public String (StringBuffer buffer) {
          synchronized(buffer) {
          buffer.setShared();
          this.value = buffer.getValue();
          this.offset = 0;
          this.count = buffer.length();
          }
          }


          在StringBuffer中:

          final char[] getValue() { return value; }


          很明顯的,這個構造函數直接把StringBuffer的char[]數組返回給了String對象。也就是現在新生成的String和StringBuffer共用同一個char[]數組,但是下面的程序為什么會打印出以下結果呢:

          StringBuffer sb = new StringBuffer("abc");
          System.out.println("StringBuffer: " + sb.toString());
          String s = new String(sb);
          System.out.println("String: " + s);
          sb.append("123");
          System.out.println("StringBuffer: " + sb);
          System.out.println("String: " + s);
          /////////////////////////////////////////////////////////////////////
          StringBuffer: abc
          String: abc
          StringBuffer: abc123
          String: abc


          分析:這個問題的核心答案在 this.count = buffer.length() 這句話上。這句話的意思是String中的count的大小為這個char[]數組中實際含有的字符的個數,而不是這個數組的大小。所以在打印的時候對于上面的String對象,只會打印3個字符,而不是6個字符!

          新的問題:如果我從StringBuffer中刪除了一個字符,那么String對象也應該受到影響了?但是為什么實際上這個String沒有發生變化呢?問題的答案在buffer.setShared()上,這句話的含義就是告訴這個StringBuffer,有其它的String對象與它共享它的char[]數組。

          這個時候,當它進行delete,insert等操作的時候,它會新生成一個char[]數組,然后再進行操作。所以這個時候String和StringBuffer就不共享同一個數組了,String自然也就不會受到影響了。

          為什么要用這么復雜的方法呢?答案是“節省內存資源”。可以想想,我們在程序中使用最頻繁的對象都有哪些,答案肯定包含String。而我們知道,在拼裝一個String的時候,使用StringBuffer效率最高。所以我們會先用StringBuffer動態的拼裝好一個字符串,然后再把它轉化成String對象,這個時候就會突顯這種方式的經典之處了。下面是StringBuffer的toString()方法:

          public String toString() {
          return new String(this);
          }


          public String (StringBuffer buffer) {
          synchronized(buffer) {
          buffer.setShared();
          this.value = buffer.getValue();
          this.offset = 0;
          this.count = buffer.length();
          }
          }


          在StringBuffer中:

          final char[] getValue() { return value; }


          很明顯的,這個構造函數直接把StringBuffer的char[]數組返回給了String對象。也就是現在新生成的String和StringBuffer共用同一個char[]數組,但是下面的程序為什么會打印出以下結果呢:

          StringBuffer sb = new StringBuffer("abc");
          System.out.println("StringBuffer: " + sb.toString());
          String s = new String(sb);
          System.out.println("String: " + s);
          sb.append("123");
          System.out.println("StringBuffer: " + sb);
          System.out.println("String: " + s);
          /////////////////////////////////////////////////////////////////////
          StringBuffer: abc
          String: abc
          StringBuffer: abc123
          String: abc


          分析:這個問題的核心答案在 this.count = buffer.length() 這句話上。這句話的意思是String中的count的大小為這個char[]數組中實際含有的字符的個數,而不是這個數組的大小。所以在打印的時候對于上面的String對象,只會打印3個字符,而不是6個字符!

          新的問題:如果我從StringBuffer中刪除了一個字符,那么String對象也應該受到影響了?但是為什么實際上這個String沒有發生變化呢?問題的答案在buffer.setShared()上,這句話的含義就是告訴這個StringBuffer,有其它的String對象與它共享它的char[]數組。

          這個時候,當它進行delete,insert等操作的時候,它會新生成一個char[]數組,然后再進行操作。所以這個時候String和StringBuffer就不共享同一個數組了,String自然也就不會受到影響了。

          為什么要用這么復雜的方法呢?答案是“節省內存資源”。可以想想,我們在程序中使用最頻繁的對象都有哪些,答案肯定包含String。而我們知道,在拼裝一個String的時候,使用StringBuffer效率最高。所以我們會先用StringBuffer動態的拼裝好一個字符串,然后再把它轉化成String對象,這個時候就會突顯這種方式的經典之處了。下面是StringBuffer的toString()方法:

          public String toString() {
          return new String(this);
          }

          ]]>
          posted on 2005-09-20 14:28 Sung 閱讀(161) 評論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 玉田县| 江门市| 中牟县| 龙井市| 盐源县| 盐津县| 景东| 义乌市| 石台县| 桃园市| 新田县| 清水河县| 神木县| 法库县| 桂林市| 宣武区| 和平县| 安西县| 东台市| 齐河县| 台南县| 嘉荫县| 都昌县| 合川市| 甘孜县| 高陵县| 乌苏市| 西盟| 禹城市| 镇原县| 鹤庆县| 安西县| 陕西省| 西畴县| 四川省| 扬州市| 吉安县| 柏乡县| 汶川县| 凌源市| 夏河县|