程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> 深入JAVA對象深度克隆的詳解

深入JAVA對象深度克隆的詳解

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

也許你會說,用clone()不就行了?!你的想法只對了一半,因為用clone()時,除了基礎數據和String類型的不受影響外,其他復雜類型(如集合、對象等)還是會受到影響的!除非你對每個對象裡的復雜類型又進行了clone(),但是如果一個對象的層次非常深,那麼clone()起來非常復雜,還有可能出現遺漏!
既然用等號和clone()復制對象都會對原來對象產生影響,那麼應該怎麼做才能實現復制後的對象不對原來對象有任何影響呢?

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

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

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

public Object copy() throws IOException, ClassNotFoundException{
   ByteArrayOutputStream bos = new ByteArrayOutputStream();
   ObjectOutputStream oos = new ObjectOutputStream(bos);
   oos.writeObject(this);
   ObjectInputStream ois = new ObjectInputStream(new ByteArrayInputStream(bos.toByteArray()));
   return ois.readObject();
  }
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved