Serializable接口实现深度克隆
生活随笔
收集整理的這篇文章主要介紹了
Serializable接口实现深度克隆
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
此時實現的Clone是深度克隆:
public class Inner implements Serializable {private static final long serialVersionUID = 872390113109L; //最好是顯式聲明IDpublic String name = "";public Inner(String name) {this.name = name;}public String getName() {return name;}public void setName(String name) {this.name = name;}@Overridepublic String toString() {return "Inner的name值為:" + name;} } public class Outer implements Serializable {private static final long serialVersionUID = 369285298572941L; //最好是顯式聲明IDpublic Inner inner;//Discription:[深度復制方法,需要對象及對象所有的對象屬性都實現序列化] public Outer myclone() {Outer outer = null;try { // 將該對象序列化成流,因為寫在流里的是對象的一個拷貝,而原對象仍然存在于JVM里面。所以利用這個特性可以實現對象的深拷貝ByteArrayOutputStream baos = new ByteArrayOutputStream();ObjectOutputStream oos = new ObjectOutputStream(baos);oos.writeObject(this);// 將流序列化成對象ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());ObjectInputStream ois = new ObjectInputStream(bais);outer = (Outer) ois.readObject();} catch (IOException e) {e.printStackTrace();} catch (ClassNotFoundException e) {e.printStackTrace();}return outer;}public Outer(Inner inner) {this.inner = inner;}@Overridepublic String toString() {return "Outer{" +"inner=" + inner +'}';}public static void main(String[] args) throws CloneNotSupportedException {Inner inner = new Inner("內1");Outer outer = new Outer(inner);Outer outer1 = outer.myclone();//兩個對象在內存空間內完全獨立存在,互不影響對方的值。inner.setName("內2");System.out.println(outer);//原對象改變了System.out.println(outer1);//克隆后的對象沒改變}}輸出:
Outer{inner=Inner的name值為:內2}
Outer{inner=Inner的name值為:內1}
實現對象克隆有兩種方式:
??1). 實現Cloneable接口并重寫Object類中的clone()方法;
??2). 實現Serializable接口,通過對象的序列化和反序列化實現克隆,可以實現真正的深度克隆。
總結
以上是生活随笔為你收集整理的Serializable接口实现深度克隆的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 计算机应用技术目标地域分析100字,【计
- 下一篇: 轻量级报表工具Telerik Repor