国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

深入淺出Java clone技術(3)

2019-11-18 11:24:18
字體:
來源:轉載
供稿:網友

深入淺出java clone技術(3)

本章將進入clone的高級特性,著重講述縱深clone技術。

Clone通常有兩種類型即淺clone和深clone。首先,分析一下兩種的不同。淺clone和深clone都是clone,它們本質區別是對象內部的成員屬性(非原生類型屬性,如int等)在clone時是否處理為引用。假如仍然保留為引用,則稱為淺clone,反之稱為深clone。其實這兩個概念也是相對的概念。在處理上它們有點區別,淺clone方式得到clone對象即可,深clone方式在得到clone對象后,還需要對引用的成員屬性進行“clone”處理。從這個層次上說,深clone并沒有什么非凡地困難,簡單講就是創建好對象,再設置一些成員屬性。關于深clone,網上的文章已經有太多,有點目不暇接的感覺,本文不再贅述,這也不是本文的重點。

本文的重點是要闡述縱深clone,亦即“N深clone”。深到什么程度為止?本文描述的目標是一直深到你想要的程度,包括深到不能再深的程度。

實現方案為采用java reflection技術和遞歸相結合。

大致步驟描述如下:首先采用java reflection技術動態獲取成員方法列表。然后視clone的深度,對具備clone條件的并且有必要clone的成員進行逐一clone。這是一個遞歸的過程,直到clolne深度已到為止或者到對象已經沒有需要clone的成員屬性為止。

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

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

    /**

     * @return Object 返回clone的對象

     * @param obj 原對象

     * @param length clone的深度

     */

public Object deepClone(Object obj, int length) {

        Object result = obj;

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

 

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

 

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

        result = om.clone(obj);

  

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

 

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

            //對成員進行處理

 

            //假如已不需要再判定成員了,那除了“容器”成員外,已經clone結束

            if (length <= 1) {

                if (!“容器”成員) {

                    continue;

                }

                try {

                    //只需clone一次了,注重遞歸方法的深度參數傳入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)設進去

            } catch (Exception ex) {

                ex.printStackTrace();

                return result;

            }           

        }//for..

        return result;

    }

 

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



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 建昌县| 任丘市| 久治县| 宜都市| 龙州县| 东台市| 明光市| 黄大仙区| 芒康县| 西乌珠穆沁旗| 安仁县| 繁昌县| 兖州市| 奉节县| 三亚市| 南乐县| 鹤壁市| 清河县| 宜州市| 溧水县| 富宁县| 姜堰市| 茌平县| 开远市| 腾冲县| 阿拉善左旗| 石渠县| 清镇市| 岑巩县| 和平县| 安阳市| 德惠市| 鲁甸县| 连江县| 社会| 石城县| 松江区| 灵寿县| 伊川县| 全南县| 奉新县|