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

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

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

    拼搏的人生

    拼搏在繁華的都市

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      7 隨筆 :: 13 文章 :: 6 評論 :: 0 Trackbacks

    ????我們知道在Java在java中,傳參時,都是以傳值的形式進行。對于基本數據類型,傳遞的是數據的拷貝,對于引用類型,傳遞的引用的拷貝。為了獲取對象的一份拷貝,我們可以利用Object類的clone()方法。至于怎么樣來實現Clone我們必須做以下的事情:
    1> 在派生類中覆蓋基類的clone(),并聲明為public。
    2> 在派生類的clone()方法中,調用super.clone()。
    3> 在派生類中實現Cloneable接口。
    4> 沒有抽象方法的接口叫標識接口。
    5> 為什么我們在派生類中覆蓋Object的clone()方法時,一定要調用super.clone()呢?在運行時刻,Object
    ?? 的clone()方法能識別出你要復制的是哪一個對象,然后為此對象分配空間,并進行對象的復制,將原
    ?? 始對象的內容一一復制到新的對象空間去。
    我們看下面的例子:

    class TestClone
    {
    ?public static void main(String[] args)
    ? ?{
    ????? Animal an1=new Animal("Dog",50);
    ???? ?Animal an2=(Animal)an1.clone();
    ??????an2.name="Fox";
    ??? ??an2.weight=30;
    ???? ?System.out.println(an1);
    ?? ?}
    }
    class Animal implements Cloneable
    {
    ?? String name;
    ?? int weight;
    ?public Animal(String name,int weight)
    ?? {
    ?????? this.name=name;
    ???? ? this.weight=weight;
    ?? }
    ?public String toString()
    ? {
    ????? ?return "name="+name+","+"weight="+weight;
    ? }
    ?public Object clone()
    ??{
    ???? Object o=null;
    ??try
    ?? ?{
    ????? ?o=super.clone();
    ??? ?}
    ??catch(CloneNotSupportedException e)
    ??{
    ?????? System.out.println(e.toString());
    ??}
    ???? ?return o;
    ? ?}
    }
    運行結果如下:
    F:\Java Develop>javac TestClone.java
    F:\Java Develop>java TestClone
    name=Dog,weight=50
    我們看到我們修改an2的值并沒有影響到an1里的值,這就是克隆的作用.是因為在這里通過Clone我們在內存中有2塊地方用來儲存不同的an1,an2
    我們在看下面一個例子,我們再增加一個動物的飼養員類,來相關到具體的每個動物.
    class TestClone
    {
    ?public static void main(String[] args)
    ?{
    ??Feeder f=new Feeder("google",50);
    ??Animal an1=new Animal("Dog",50,f);
    ??Animal an2=(Animal)an1.clone();
    ??an2.f.name="baidu";
    ??an2.f.age=60;
    ??System.out.println(an1.f.name);
    ??System.out.println(an1.f.age);
    ?}
    }

    /*
    class Feeder implements Cloneable
    {
    ?String name;
    ?int age;
    ?public Feeder(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 Feeder
    {
    ?String name;
    ?int age;
    ?public Feeder(String name,int age)
    ?{
    ??this.name=name;
    ??this.age=age;
    ?}
    }

    class Animal implements Cloneable
    {
    ?String name;
    ?int weight;
    ?Feeder f;
    ?public Animal(String name,int weight,Feeder f)
    ?{
    ??this.name=name;
    ??this.weight=weight;
    ??this.f=f;
    ?}
    ?public String toString()
    ?{
    ??return "name="+name+","+"weight="+weight;
    ?}
    ?public Object clone()
    ?{
    ??Object o=null;
    ??//Animal o=null;
    ??try
    ??{
    ???o=super.clone();
    ??}
    ??catch(CloneNotSupportedException e)
    ??{
    ???System.out.println(e.toString());
    ??}
    ??//o.f=(Feeder)f.clone();
    ??return o;
    ?}
    }
    我們看輸出結果:
    F:\Java Develop>javac TestClone.java
    F:\Java Develop>java TestClone
    baidu
    60
    從結果可以看出來我們修改了an2.f.name和an.f.age但是an1去發生了變化,這是因為我們沒有對Feeder類進行克隆,這就是淺克隆,為了解決這個問題我們需要用到Deeply克隆,java默認的克隆方式是淺克隆.
    代碼如下:
    class TestClone
    {
    ?public static void main(String[] args)
    ?{
    ??Feeder f=new Feeder("google",50);
    ??Animal an1=new Animal("Dog",50,f);
    ??Animal an2=(Animal)an1.clone();
    ??an2.f.name="baidu";
    ??an2.f.age=60;
    ??System.out.println(an1.f.name);
    ??System.out.println(an1.f.age);
    ?}
    }

    class Feeder implements Cloneable
    {
    ?String name;
    ?int age;
    ?public Feeder(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 Animal implements Cloneable
    {
    ?String name;
    ?int weight;
    ?Feeder f;
    ?public Animal(String name,int weight,Feeder f)
    ?{
    ??this.name=name;
    ??this.weight=weight;
    ??this.f=f;
    ?}
    ?public String toString()
    ?{
    ??return "name="+name+","+"weight="+weight;
    ?}
    ?public Object clone()
    ?{
    ??//Object o=null;
    ??Animal o=null;
    ??try
    ??{
    ???o=(Animal)super.clone();
    ??}
    ??catch(CloneNotSupportedException e)
    ??{
    ???System.out.println(e.toString());
    ??}
    ??o.f=(Feeder)f.clone();
    ??return o;
    ?}
    }
    輸出結果如下:
    F:\Java Develop>javac TestClone.java
    F:\Java Develop>java TestClone
    google
    50
    java淺克隆是指copy類里所有沒有引用類型的變量.Deeply Clone則剛好相反.

    posted on 2006-05-07 21:52 Dalston.Young 閱讀(314) 評論(1)  編輯  收藏 所屬分類: Java Core

    評論

    # re: 淺談Java的Clone 2006-11-20 16:35 坎井之蛙
    通俗易懂!3Q!  回復  更多評論
      


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 免费人成在线观看播放a| 色婷婷六月亚洲综合香蕉| 成年女人A毛片免费视频| 亚洲国产中文字幕在线观看| 亚洲sm另类一区二区三区| 免费鲁丝片一级观看| 久久亚洲中文无码咪咪爱| 国产一级淫片视频免费看| 精品特级一级毛片免费观看| 亚洲成人影院在线观看| 一级毛片免费播放男男| 国产成人精品曰本亚洲79ren| GOGOGO免费观看国语| 久久国产亚洲精品无码| 久久午夜免费视频| 亚洲精品精华液一区二区| 国产精品无码一区二区三区免费| 色屁屁在线观看视频免费| 中文字幕亚洲综合久久男男 | 最近中文字幕大全免费版在线 | 国产亚洲精品美女| 久久综合亚洲色HEZYO国产| 中文字幕无码一区二区免费| 亚洲黄色网址在线观看| 毛片免费在线观看网站| 一个人看的www免费在线视频| 亚洲成av人在线视| 毛片A级毛片免费播放| v片免费在线观看| 亚洲av成人无码久久精品| 好先生在线观看免费播放| 一级做a爰片久久免费| 亚洲成AV人综合在线观看| 国产美女精品视频免费观看| 99精品免费视品| 国产成人亚洲精品| 日本亚洲欧洲免费天堂午夜看片女人员| 最近2019免费中文字幕视频三| 在线91精品亚洲网站精品成人| 亚洲精品成人片在线播放| 毛片免费观看网址|