WEB開發(fā) de 點滴

          by sanwish

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            38 隨筆 :: 0 文章 :: 4 評論 :: 0 Trackbacks

          何為具備clone條件的并且有必要clone的成員進(jìn)行逐一clone?比如,原生類型(primitive type),定為瞬態(tài)(Transient)的類型,不可訪問的類型(!Field#isAccessible()),沒實現(xiàn)Cloneable接口的類型等等,都不具備clone條件。String等java定義的類型就不需要再深入clone了,這些屬于沒必要進(jìn)行clone的情況。但List類型等 “容器”類是有必要clone的成員類型。

          據(jù)此,遞歸程序示意如下(deepClone為java 方法):

          /**

          * @return Object 返回clone的對象

          * @param obj 原對象

          * @param length clone的深度

          */

          public Object deepClone(Object obj, int length) {

          Object result = obj;

          //此處為偽代碼: 如果對象obj不具備clone條件,就返回result,這也是遞歸的結(jié)束條件。

          //此處為偽代碼: 如果對象obj沒必要clone,就返回result

          //此處為偽代碼:開始進(jìn)行“clone”對象。這地方是調(diào)一個抽象方法來處理,這樣可以增加很多靈活性。該方法主要目的是實現(xiàn)“clone”對象方案。注意:這里面的“clone”方案可能是我們想都想不到的方案,它可能有很多創(chuàng)意,但效果都是一樣的,就是要“clone”個新的對象出來。當(dāng)然最容易想的就是Object#clone()方法了。示意如下:

          result = om.clone(obj);

          //此處為偽代碼: 獲取具備clone條件的并且有必要clone的所有成員。這地方也是調(diào)一個抽象方法來處理。同樣是為了增強(qiáng)靈活性。獲取這些成員的方法有很多,可能是通過setter和getter對來得到,也可能是通過get fields 等等方法得到(這種方法可能不少成員是無法直接訪問的,往往需要結(jié)合別的方法),甚至是多種方法的綜合。總之,目的只有一個,就是獲得這些成員。

          for (int i = 0; i < fields.length; i++) {

          //對成員進(jìn)行處理

          //如果已不需要再判斷成員了,那除了“容器”成員外,已經(jīng)clone結(jié)束

          if (length <= 1) {

          if (!“容器”成員) {

          continue;

          }

          try {

          //只需clone一次了,注意遞歸方法的深度參數(shù)傳入1

          clonedFieldValue = deepClone(“容器”成員的值, 1);

          } catch (Exception ex2) {

          ex2.printStackTrace();

          return result;

          }

          } else {

          try {

          clonedFieldValue = deepClone(成員的值, length - 1);

          } catch (Exception ex) {

          ex.printStackTrace();

          return result;

          }

          }

          try {

          //此處為偽代碼:將clone好的值(clonedFieldValue)設(shè)進(jìn)去

          } catch (Exception ex) {

          ex.printStackTrace();

          return result;

          }

          }//for..

          return result;

          }

          至此,已完成了“N深clone”。下面討論一下別的相關(guān)問題。比如說這種深度clone原本是 A-->B-->C--……-->xz這樣一種情況,就是說A類含有B成員,B里面又含有C成員,依此類推。如果想在“N深 clone”時,只clone“xz”這個成員怎么辦?其實很簡單,這個問題主要是要解決在遞歸過程中有些成員需要clone同時有些成員不需clone 仍保留引用這個問題。在上面的遞歸示例中已經(jīng)提到,實現(xiàn)“clone”的“方案”已經(jīng)被定義成抽象方法,那么我們只要對這個方法做一個滿足這個需求的實現(xiàn)即可。

          posted on 2008-11-07 11:07 sanwish 閱讀(132) 評論(0)  編輯  收藏 所屬分類: java
          主站蜘蛛池模板: 文登市| 常德市| 稻城县| 湘潭市| 威远县| 乳山市| 来宾市| 萨迦县| 三原县| 开原市| 龙海市| 金乡县| 南宁市| 安义县| 多伦县| 高尔夫| 华阴市| 三亚市| 凌源市| 旬邑县| 岗巴县| 九江市| 石阡县| 肃宁县| 兴义市| 湖州市| 江达县| 兴国县| 平泉县| 石城县| 遵义市| 汾西县| 新昌县| 汝南县| 渝北区| 武胜县| 天等县| 禹州市| 湘潭市| 长丰县| 龙口市|