摘要:克隆復制一份被克隆的類實現接口,覆蓋方法,返回調用父類的即可。省略其余代碼然后,克隆時只須調用我們剛剛覆蓋的。總結克隆就是復制一份。
何謂深淺?程度而已。
克隆:復制一份
被克隆的類實現Cloneable接口,覆蓋clone()方法,返回調用父類的clone()即可。
public class Person implements Cloneable{ @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } //...省略其余代碼 }
然后,克隆時只須調用我們剛剛覆蓋的clone()。
淺拷貝現在有Child類:
public class Child{ //...省略其余代碼 }
還有Person類:
public class Person implements Cloneable{ private int age; private String name; private Child child; //...省略其余代碼 }
克隆Person對象p1賦給p2,然后我們看看他們的toString()和hashCode()結果:
public class Main { public static void main(String[] args) throws CloneNotSupportedException { Person p1 = new Person("zhangsan",23); p1.setChild(new Child("xiaoming", 1);); //克隆操作 Person p2 = p1.clone(); //打印看看 System.out.println(p1+", "+p1.hashCode()+", "+p1.getChild().hashCode()); System.out.println(p2+", "+p2.hashCode()+", "+p2.getChild().hashCode()); } }
輸出:
Person [age=23, name=zhangsan, value=666, child=Child [name=xiaoming, age=1]], 118352462, 1550089733 Person [age=23, name=zhangsan, value=666, child=Child [name=xiaoming, age=2]], 865113938, 1550089733
結論:p1,p2成員的值相等,但它們是兩個不同的對象,他們的Child成員是同一個對象。
深拷貝給Child也實現Cloneable接口并覆蓋clone():
public class Child implements Cloneable{ @Override protected Object clone() throws CloneNotSupportedException { return super.clone();; } //...省略其余代碼 }
然后,改變Person類的clone()的實現:
public class Person implements Cloneable{ @Override protected Object clone() throws CloneNotSupportedException { Person p = (Person)super.clone(); p.setChild((Child)child.clone()); return p; } //...省略其余代碼 }
然后再調用上面的main(String [] args),結果是:
Person [age=23, name=zhangsan, value=666, child=Child [name=xiaoming, age=1]], 118352462, 1550089733 Person [age=23, name=zhangsan, value=666, child=Child [name=xiaoming, age=2]], 865113938, 1442407170
結論:p1,p2是兩個不同的對象,他們的Child成員也是兩個不同的對象。
總結克隆就是復制一份。
淺拷貝就是簡單復制值,如果有引用成員,他們的引用成員將是同一個對象,深拷貝則不為然。
為什么呢
可以這樣認為,調用誰的clone()就是就是對誰深拷貝。
在上面淺拷貝的例子中,因為調用了p1對象的clone(),所以p1和p2是兩個不同的對象(對p1,p2本身深拷貝);在深拷貝的例子中,不但調用了p1的clone(),也調用Child類型對象的clone(),所以兩個Child類型對象不同(對所有對象深拷貝)。
思考基于上述例子,如何實現Person類的clone(),使得只對Child成員進行深拷貝,而不對Person本身深拷貝?
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/73651.html
摘要:基礎問題的的性能及原理之區別詳解備忘筆記深入理解流水線抽象關鍵字修飾符知識點總結必看篇中的關鍵字解析回調機制解讀抽象類與三大特征時間和時間戳的相互轉換為什么要使用內部類對象鎖和類鎖的區別,,優缺點及比較提高篇八詳解內部類單例模式和 Java基礎問題 String的+的性能及原理 java之yield(),sleep(),wait()區別詳解-備忘筆記 深入理解Java Stream流水...
摘要:基礎問題的的性能及原理之區別詳解備忘筆記深入理解流水線抽象關鍵字修飾符知識點總結必看篇中的關鍵字解析回調機制解讀抽象類與三大特征時間和時間戳的相互轉換為什么要使用內部類對象鎖和類鎖的區別,,優缺點及比較提高篇八詳解內部類單例模式和 Java基礎問題 String的+的性能及原理 java之yield(),sleep(),wait()區別詳解-備忘筆記 深入理解Java Stream流水...
摘要:基礎問題的的性能及原理之區別詳解備忘筆記深入理解流水線抽象關鍵字修飾符知識點總結必看篇中的關鍵字解析回調機制解讀抽象類與三大特征時間和時間戳的相互轉換為什么要使用內部類對象鎖和類鎖的區別,,優缺點及比較提高篇八詳解內部類單例模式和 Java基礎問題 String的+的性能及原理 java之yield(),sleep(),wait()區別詳解-備忘筆記 深入理解Java Stream流水...
摘要:哪吒社區技能樹打卡打卡貼函數式接口簡介領域優質創作者哪吒公眾號作者架構師奮斗者掃描主頁左側二維碼,加入群聊,一起學習一起進步歡迎點贊收藏留言前情提要無意間聽到領導們的談話,現在公司的現狀是碼農太多,但能獨立帶隊的人太少,簡而言之,不缺干 ? 哪吒社區Java技能樹打卡?【打卡貼 day2...
閱讀 2474·2021-11-16 11:45
閱讀 2444·2021-10-11 10:59
閱讀 2251·2021-10-08 10:05
閱讀 3817·2021-09-23 11:30
閱讀 2370·2021-09-07 09:58
閱讀 790·2019-08-30 15:55
閱讀 773·2019-08-30 15:53
閱讀 1923·2019-08-29 17:00