Cloneable接口是一个空接口,仅用于标记对象,Cloneable接口里面是没有clone()方法,的clone()方法是Object类里面的方法!默认实现是一个Native方法
protected native Object clone() throws CloneNotSupportedException;
如果对象implement Cloneable接口的话,需要覆盖clone方法(因为Object类的clone方法是protected,需要覆盖为public)
public Object clone() throws CloneNotSupportedException{ return super.clone(); }
Object类里的clone()方法仅仅用于浅拷贝(拷贝基本成员属性,对于引用类型仅返回指向改地址的引用)
深拷贝需要重新覆盖Clone方法。
public class testDeepClone implements Cloneable { public int num = 0; public String str = "default"; public A a; public Object clone() throws CloneNotSupportedException { testDeepClone o = (testDeepClone) super.clone(); o.str = new String(this.str); o.a = (A) a.clone(); return o; } } // 成员属性A必须为Cloneable的,否则无法Clone其组合的类 class A implements Cloneable { public Object clone() throws CloneNotSupportedException { return super.clone(); } }
利用串行化来实现深层复制
把对象写到流中的过程是串行化(Serilization)过程,而把对象从流中读出来是并行化(Deserialization)过程。应当指出的是,写在流中的是对象的一个拷贝,而原来对象仍然存在JVM里面。
在Java语言里深层复制一个对象,常常可以先使对象实现Serializable接口,然后把对象(实际上只是对象的一个拷贝)写到一个流中,再从流中读出来,便可以重建对象。
这样做的前提是对象以及对象内部所有引用到的对象都是可串行化的,否则,就需要仔细考察那些不可串行化的对象是否设成transient,从而将之排除在复制过程之外。代码改进如下:
原文:http://www.cnblogs.com/tonyluis/p/5778266.html