JAVA對象clone方法代碼實(shí)例解析
1.Cloneable接口
這個(gè)接口一個(gè)方法都沒有,但是要使用clone方法,就必須實(shí)現(xiàn)這個(gè)接口,否則拋出CloneNotSupportedException異常
2.clone方法的返回值
先附上兩個(gè)類代碼
package pojo;/** * @Author : ZGQ * @Date : 2020/3/11 22:12 * @Version : 1.0 */public class Person implements Cloneable{ String name; int age; public Person(String name, int age) { this.name = name; this.age = age; } @Override protected Object clone() throws CloneNotSupportedException { System.out.println(super.clone().getClass()); Person p = (Person) super.clone(); p.name=this.name; p.age=this.age; return p; }}
package pojo;/** * @Author : ZGQ * @Date : 2020/3/11 22:21 * @Version : 1.0 */public class Girl extends Person { char cup; public Girl(String name, int age, char cup) { super(name, age); this.cup = cup; } @Override public Object clone() throws CloneNotSupportedException { System.out.println(super.clone().getClass()); Girl girl = (Girl) super.clone(); girl.cup=this.cup; return girl; } @Override public String toString() { return 'Girl{' +'cup=' + cup +', name=’' + name + ’’’ +', age=' + age +’}’; }}
我一開始很困惑,為什么clone方法可以將父類的實(shí)例交給子類的引用,輸出一看才知道,在第一次clone時(shí),創(chuàng)建的就是子類的對象
再創(chuàng)建一個(gè)boys類,或者直接調(diào)用Person.clone也一樣,誰調(diào)用clone方法,就創(chuàng)建誰的實(shí)例
調(diào)用girl.clone()
調(diào)用person.clone()
調(diào)用boy.clone()
3.如果一個(gè)類沒有實(shí)現(xiàn)Cloneable接口,那它就不可以被clone,它的子類也就不可能實(shí)現(xiàn)真正的深復(fù)制
多嘴一句,為什么不把clone方法定義在Cloneable中呢?
4.以上寫法就是深復(fù)制的寫法
5.為什么調(diào)用clone出來的是子類的實(shí)例呢?
可以顯而易見的是確實(shí)這樣比較合乎情理,但是java語言向我們隱瞞了實(shí)現(xiàn)細(xì)節(jié),又是一個(gè)開后門的語法,像包裝類可以使用運(yùn)算符直接運(yùn)算一樣無恥
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. IntelliJ IDEA設(shè)置條件斷點(diǎn)的方法步驟2. IntelliJ IDEA導(dǎo)入jar包的方法3. SSM框架JSP使用Layui實(shí)現(xiàn)layer彈出層效果4. 刪除docker里建立容器的操作方法5. IntelliJ IDEA導(dǎo)出項(xiàng)目的方法6. 基于android studio的layout的xml文件的創(chuàng)建方式7. Python產(chǎn)生batch數(shù)據(jù)的操作8. Java導(dǎo)出Execl疑難點(diǎn)處理的實(shí)現(xiàn)9. 淺談定義一個(gè)PHP函數(shù)10. IDEA創(chuàng)建SpringBoot的maven項(xiàng)目的方法步驟
