有時候,我們需要把對象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 }