JAVA對象的深度克隆


有時候,我們需要把對象A的所有值復制給對象B(B = A),但是這樣用等號給賦值你會發現,當B中的某個對象值改變時,同時也會修改到A中相應對象的值!

  也許你會說,用clone()不就行了?!你的想法只對了一半,因為用clone()時,除了基礎數據和String類型的不受影響外,其他復雜類型(如集合、對象等)還是會受到影響的!除非你對每個對象里的復雜類型又進行了clone(),但是如果一個對象的層次非常深,那么clone()起來非常復雜,還有可能出現遺漏!

  既然用等號和clone()復制對象都會對原來對象產生影響,那么應該怎么做才能實現復制后的對象不對原來對象有任何影響呢?

  其實很簡單,用對象的深度克隆,這種克隆實現了克隆后的對象和原來的對象是獨立開來的!

  對象的深度克隆原理:將對象序列化后寫在輸出流里,因為寫在流里面的對象是一份拷貝,原對象仍然在JVM里;然后再把輸出流轉換為輸入流,把對象反序列化后寫出來!這樣就實現了對象的深度克隆,克隆后的兩個對象完全獨立開來,互不影響!

  你會發現對象的深度克隆其實是利用的對象的序列化和反序列化,所以要進行深度克隆的對象都要實現Serializable接口!

  進行深度克隆的實現代碼如下:

1 public Object copy() throws IOException, ClassNotFoundException{ 2    ByteArrayOutputStream bos = new ByteArrayOutputStream(); 3    ObjectOutputStream oos = new ObjectOutputStream(bos); 4    oos.writeObject(this);
5 ObjectInputStream ois = new ObjectInputStream(new ByteArrayInputStream(bos.toByteArray())); 6 return ois.readObject(); 7 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM