<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-59  評(píng)論-31  文章-0  trackbacks-0

    1.淺復(fù)制和深復(fù)制概念
    ⑴淺復(fù)制(淺克?。?br /> 被復(fù)制對(duì)象的任何變量都含有和原來的對(duì)象相同的值,而任何的對(duì)其他對(duì)象的引用仍然指向原來的對(duì)象。換言之,淺復(fù)制僅僅復(fù)制所考慮的對(duì)象,而不復(fù)制他所引用的對(duì)象。
     
    ⑵深復(fù)制(深克隆)
    被復(fù)制對(duì)象的任何變量都含有和原來的對(duì)象相同的值,除去那些引用其他對(duì)象的變量。那些引用其他對(duì)象的變量將指向被復(fù)制過的新對(duì)象,而不再是原有的那些被引用的對(duì)象。換言之,深復(fù)制把要復(fù)制的對(duì)象所引用的對(duì)象都復(fù)制了一遍。
     
    2.Java的clone()方法
    ⑴clone方法將對(duì)象復(fù)制了一份并返回給調(diào)用者。一般而言,clone()方法滿足:
    ①對(duì)任何的對(duì)象x,都有x.clone() !=x//克隆對(duì)象和原對(duì)象不是同一個(gè)對(duì)象
    ②對(duì)任何的對(duì)象x,都有x.clone().getClass()= =x.getClass()//克隆對(duì)象和原對(duì)象的類型相同
    ③假如對(duì)象x的equals()方法定義恰當(dāng),那么x.clone().equals(x)應(yīng)該成立。
     
    ⑵Java中對(duì)象的克隆
    ①為了獲取對(duì)象的一份拷貝,我們能夠利用Object類的clone()方法。
    ②在派生類中覆蓋基類的clone()方法,并聲明為public。
    ③在派生類的clone()方法中,調(diào)用super.clone()。
    ④在派生類中實(shí)現(xiàn)Cloneable接口。
     
    請(qǐng)看如下代碼:
     
    class Student implements Cloneable
    {
        String name;
        int age;
        Student(String name,int age)
        {
            this.name=name;
            this.age=age;
        }
        public Object clone()
        {
            Object o=null;
            try
            {
            o=(Student)super.clone();//Object中的clone()識(shí)別出您要復(fù)制的是哪一
    // 個(gè)對(duì)象。
            }
            catch(CloneNotSupportedException e)
            {
                System.out.println(e.toString());
            }
            return o;
        }

       public static void main(String[] args) {
          Student s1=new Student("zhangsan",18);
          Student s2=(Student)s1.clone();
          s2.name="lisi";
          s2.age=20;
    System.out.println("name="+s1.name+","+"age="+s1.age);//修改學(xué)生2后,不影響
    學(xué)生1的值。
       }
    }
     
     
    說明:
    ①為什么我們?cè)谂缮愔懈采wObject的clone()方法時(shí),一定要調(diào)用super.clone()呢?在運(yùn)行時(shí)刻,Object中的clone()識(shí)別出您要復(fù)制的是哪一個(gè)對(duì)象,然后為此對(duì)象分配空間,并進(jìn)行對(duì)象的復(fù)制,將原始對(duì)象的內(nèi)容一一復(fù)制到新對(duì)象的存儲(chǔ)空間中。
    ②繼承自java.lang.Object類的clone()方法是淺復(fù)制。以下代碼能夠證實(shí)之。
     
    class Professor
    {
        String name;
        int age;
        Professor(String name,int age)
        {
            this.name=name;
            this.age=age;
        }
    }
    class Student implements Cloneable
    {
        String name;//常量對(duì)象。
        int age;
        Professor p;//學(xué)生1和學(xué)生2的引用值都是相同的。
        Student(String name,int age,Professor p)
        {
            this.name=name;
            this.age=age;
            this.p=p;
        }
        public Object clone()
        {
            Student o=null;
            try
            {
                o=(Student)super.clone();
            }
            catch(CloneNotSupportedException e)
            {
                System.out.println(e.toString());
            }
            o.p=(Professor)p.clone();
            return o;
        }

       
    public static void main(String[] args)
        {
          Professor p=new Professor("wangwu",50);
          Student s1=new Student("zhangsan",18,p);
          Student s2=(Student)s1.clone();
          s2.p.name="lisi";
         s2.p.age=30;
    System.out.println("name="+s1.p.name+","+"age="+s1.p.age);//學(xué)生1的教授成為lisi,age為30。
    }
    }

     

    那應(yīng)該如何實(shí)現(xiàn)深層次的克隆,即修改s2的教授不會(huì)影響s1的教授?代碼改進(jìn)如下。
     
    改進(jìn)使學(xué)生1的Professor不改變(深層次的克隆)
    class Professor implements Cloneable
    {
        String name;
        int age;
        Professor(String name,int age)
        {
            this.name=name;
            this.age=age;
        }
        public Object clone()
        {
            Object o=null;
            try
            {
                o=super.clone();
            }
            catch(CloneNotSupportedException e)
            {
                System.out.println(e.toString());
            }
            return o;
        }
    }
    class Student implements Cloneable
    {
        String name;
        int age;
        Professor p;
        Student(String name,int age,Professor p)
        {
            this.name=name;
            this.age=age;
            this.p=p;
        }
        public Object clone()
        {
            Student o=null;
            try
            {
                o=(Student)super.clone();
            }
            catch(CloneNotSupportedException e)
            {
                System.out.println(e.toString());
            }
            o.p=(Professor)p.clone();
            return o;
        }

       
    public static void main(String[] args)
        {
          Professor p=new Professor("wangwu",50);
          Student s1=new Student("zhangsan",18,p);
          Student s2=(Student)s1.clone();
          s2.p.name="lisi";
         s2.p.age=30;
    System.out.println("name="+s1.p.name+","+"age="+s1.p.age);//學(xué)生1的教授不改變。
    }
    }
     
     
    3.利用串行化來做深復(fù)制
    把對(duì)象寫到流里的過程是串行化(Serilization)過程,但是在Java程式師圈子里又很形象地稱為“冷凍”或“腌咸菜(picking)”過程;而把對(duì)象從流中讀出來的并行化(Deserialization)過程則叫做“解凍”或“回鮮(depicking)”過程。應(yīng)當(dāng)指出的是,寫在流里的是對(duì)象的一個(gè)拷貝,而原對(duì)象仍然存在于JVM里面,因此“腌成咸菜”的只是對(duì)象的一個(gè)拷貝,Java咸菜還能夠回鮮。
    在Java語(yǔ)言里深復(fù)制一個(gè)對(duì)象,常常能夠先使對(duì)象實(shí)現(xiàn)Serializable接口,然后把對(duì)象(實(shí)際上只是對(duì)象的一個(gè)拷貝)寫到一個(gè)流里(腌成咸菜),再?gòu)牧骼镒x出來(把咸菜回鮮),便能夠重建對(duì)象。
    如下為深復(fù)制源代碼。
    public Object deepClone()
    {
     //將對(duì)象寫到流里
     ByteArrayOutoutStream bo=new ByteArrayOutputStream();
     ObjectOutputStream oo=new ObjectOutputStream(bo);
     oo.writeObject(this);
     //從流里讀出來
     ByteArrayInputStream bi=new ByteArrayInputStream(bo.toByteArray());
     ObjectInputStream oi=new ObjectInputStream(bi);
     return(oi.readObject());
    }
     
    這樣做的前提是對(duì)象連同對(duì)象內(nèi)部任何引用到的對(duì)象都是可串行化的,否則,就需要仔細(xì)考察那些不可串行化的對(duì)象可否設(shè)成transient,從而將之排除在復(fù)制過程之外。上例代碼改進(jìn)如下。
     
    class Professor implements Serializable
    {
        String name;
        int age;
        Professor(String name,int age)
        {
            this.name=name;
            this.age=age;
        }
    }
    class Student implements Serializable
    {
        String name;//常量對(duì)象。
        int age;
        Professor p;//學(xué)生1和學(xué)生2的引用值都是相同的。
        Student(String name,int age,Professor p)
        {
            this.name=name;
            this.age=age;
            this.p=p;
        }
        public Object deepClone() throws IOException,
    OptionalDataException,ClassNotFoundException
    {
     //將對(duì)象寫到流里
     ByteArrayOutoutStream bo=new ByteArrayOutputStream();
     ObjectOutputStream oo=new ObjectOutputStream(bo);
     oo.writeObject(this);
     //從流里讀出來
     ByteArrayInputStream bi=new ByteArrayInputStream(bo.toByteArray());
     ObjectInputStream oi=new ObjectInputStream(bi);
     return(oi.readObject());
    }
    public static void main(String[] args)
        {
          Professor p=new Professor("wangwu",50);
          Student s1=new Student("zhangsan",18,p);
          Student s2=(Student)s1.deepClone();
          s2.p.name="lisi";
         s2.p.age=30;
    System.out.println("name="+s1.p.name+","+"age="+s1.p.age); //學(xué)生1的教授不改變。
    }
    }

    posted on 2009-06-20 18:03 RoyPayne 閱讀(171) 評(píng)論(0)  編輯  收藏 所屬分類: java基礎(chǔ)
    主站蜘蛛池模板: 国产免费人人看大香伊| 久久香蕉国产线看观看亚洲片| 一级毛片完整版免费播放一区| 亚洲中文字幕在线乱码| 精品熟女少妇av免费久久| 一区二区亚洲精品精华液| 日韩精品电影一区亚洲| 性xxxx视频播放免费| 一级黄色片免费观看| 亚洲色欲www综合网| 亚洲国产成人久久笫一页| 国产成人精品无码免费看| 亚洲人成人网站18禁| 国产AV无码专区亚洲A∨毛片| 永久免费毛片在线播放| aa级女人大片喷水视频免费| 亚洲色成人WWW永久在线观看| 亚洲热线99精品视频| 免费涩涩在线视频网| 99免费视频观看| 国产免费人成视频尤勿视频| 精品丝袜国产自在线拍亚洲| 亚洲精品V欧洲精品V日韩精品| 啦啦啦www免费视频| 日韩视频在线观看免费| 免费毛片毛片网址| 亚洲激情视频图片| 久久久久亚洲AV成人无码网站| 一区国严二区亚洲三区| 国产乱码免费卡1卡二卡3卡| 最新国产乱人伦偷精品免费网站 | 女人18特级一级毛片免费视频| a级精品九九九大片免费看| 午夜亚洲国产理论片二级港台二级| 蜜芽亚洲av无码精品色午夜| 亚洲乱码中文字幕综合234| 99re热免费精品视频观看 | 菠萝菠萝蜜在线免费视频| 亚洲国产韩国一区二区| 亚洲精品夜夜夜妓女网| 亚洲国产成人久久综合区|