深入JAVA對象深度克隆的詳解
更新時間:2013年05月17日 09:52:26 作者:
本篇文章是對JAVA對象深度克隆進行了詳細的分析介紹,需要的朋友參考下
有時候,我們需要把對象A的所有值復(fù)制給對象B(B = A),但是這樣用等號給賦值你會發(fā)現(xiàn),當B中的某個對象值改變時,同時也會修改到A中相應(yīng)對象的值!
也許你會說,用clone()不就行了?!你的想法只對了一半,因為用clone()時,除了基礎(chǔ)數(shù)據(jù)和String類型的不受影響外,其他復(fù)雜類型(如集合、對象等)還是會受到影響的!除非你對每個對象里的復(fù)雜類型又進行了clone(),但是如果一個對象的層次非常深,那么clone()起來非常復(fù)雜,還有可能出現(xiàn)遺漏!
既然用等號和clone()復(fù)制對象都會對原來對象產(chǎn)生影響,那么應(yīng)該怎么做才能實現(xiàn)復(fù)制后的對象不對原來對象有任何影響呢?
其實很簡單,用對象的深度克隆,這種克隆實現(xiàn)了克隆后的對象和原來的對象是獨立開來的!
對象的深度克隆原理:將對象序列化后寫在輸出流里,因為寫在流里面的對象是一份拷貝,原對象仍然在JVM里;然后再把輸出流轉(zhuǎn)換為輸入流,把對象反序列化后寫出來!這樣就實現(xiàn)了對象的深度克隆,克隆后的兩個對象完全獨立開來,互不影響!
你會發(fā)現(xiàn)對象的深度克隆其實是利用的對象的序列化和反序列化,所以要進行深度克隆的對象都要實現(xiàn)Serializable接口!
進行深度克隆的實現(xiàn)代碼如下:
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();
}
也許你會說,用clone()不就行了?!你的想法只對了一半,因為用clone()時,除了基礎(chǔ)數(shù)據(jù)和String類型的不受影響外,其他復(fù)雜類型(如集合、對象等)還是會受到影響的!除非你對每個對象里的復(fù)雜類型又進行了clone(),但是如果一個對象的層次非常深,那么clone()起來非常復(fù)雜,還有可能出現(xiàn)遺漏!
既然用等號和clone()復(fù)制對象都會對原來對象產(chǎn)生影響,那么應(yīng)該怎么做才能實現(xiàn)復(fù)制后的對象不對原來對象有任何影響呢?
其實很簡單,用對象的深度克隆,這種克隆實現(xiàn)了克隆后的對象和原來的對象是獨立開來的!
對象的深度克隆原理:將對象序列化后寫在輸出流里,因為寫在流里面的對象是一份拷貝,原對象仍然在JVM里;然后再把輸出流轉(zhuǎn)換為輸入流,把對象反序列化后寫出來!這樣就實現(xiàn)了對象的深度克隆,克隆后的兩個對象完全獨立開來,互不影響!
你會發(fā)現(xiàn)對象的深度克隆其實是利用的對象的序列化和反序列化,所以要進行深度克隆的對象都要實現(xiàn)Serializable接口!
進行深度克隆的實現(xiàn)代碼如下:
復(fù)制代碼 代碼如下:
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();
}
相關(guān)文章
Java如何將字符串String轉(zhuǎn)換為整型Int
這篇文章主要介紹了Java如何將字符串String轉(zhuǎn)換為整型Int,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-08-08解釋為什么Java中“1000==1000”為false而”100==100“為true
在日常編程中,我們經(jīng)常遇到一些看似簡單卻隱藏著復(fù)雜邏輯的問題,這篇文章主要介紹了解釋為什么Java中“1000==1000”為false而”100==100“為true,需要的朋友可以參考下2024-01-01基于SpringBoot和MongoDB實現(xiàn)實時分析和日志處理功能
實時分析和日志處理在現(xiàn)代應(yīng)用程序開發(fā)中扮演著重要的角色,MongoDB是一個非常流行的NoSQL數(shù)據(jù)庫,其高性能和靈活性使其成為實時分析和日志處理的理想選擇,本文將介紹如何使用?Spring?Boot?和?MongoDB?實現(xiàn)實時分析和日志處理的功能2023-06-06Java基礎(chǔ)總結(jié)之Thymeleaf詳解
Thymeleaf是一種現(xiàn)代的基于服務(wù)器端的Java模板引擎技術(shù),也是一個優(yōu)秀的面向Java的XML、XHTML、HTML5頁面模板,它具有豐富的標簽語言、函數(shù)和表達式,在使用Spring Boot框架進行頁面設(shè)計時,一般會選擇Thymeleaf模板,需要的朋友可以參考下2021-05-05往DAO類中注入@PersistenceContext和@Resource的區(qū)別詳解
這篇文章主要介紹了往DAO類中注入@PersistenceContext和@Resource的區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02