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
          主站蜘蛛池模板: 皋兰县| 黄石市| 芒康县| 苏尼特左旗| 丁青县| 杭州市| 平潭县| 那坡县| 江孜县| 赫章县| 仁寿县| 泰宁县| 鄂尔多斯市| 兴隆县| 普定县| 浦城县| 崇礼县| 南江县| 双辽市| 高州市| 白城市| 丹巴县| 朝阳区| 克拉玛依市| 合川市| 盐亭县| 霍城县| 界首市| 灵宝市| 习水县| 张家川| 塔河县| 长岛县| 岳阳县| 聂荣县| 盐源县| 夏邑县| 辽阳县| 通河县| 普兰店市| 澎湖县|