淺析Java中clone()方法淺克隆與深度克隆
現(xiàn)在Clone已經(jīng)不是一個新鮮詞語了,伴隨著“多莉”的產(chǎn)生這個詞語確實很“火”過一陣子,在Java中也有這么一個概念,它可以讓我們很方便的“制造”出一個對象的副本來,下面來具體看看Java中的Clone機制是如何工作的?
1. Clone&Copy
假設(shè)現(xiàn)在有一個Employee對象,Employee tobby =new Employee(“CMTobby”,5000),通
常我們會有這樣的賦值Employee cindyelf=tobby,這個時候只是簡單了copy了一下reference,cindyelf和tobby都指向內(nèi)存中同一個object,這樣cindyelf或者tobby的一個操作都可能影響到對方。
打個比方,如果我們通過cindyelf.raiseSalary()方法改變了salary域的值,那么tobby通過getSalary()方法得到的就是修改之后的salary域的值,顯然這不是我們愿意看到的。我們希望得到tobby的一個精確拷貝,同時兩者互不影響,這時候我們就可以使用Clone來滿足我們的需求。
Employee cindy=tobby.clone(),這時會生成一個新的Employee對象,并且和tobby具有相同的屬性值和方法。
2. Shallow Clone&Deep Clone
Clone是如何完成的呢?Object在對某個對象實施Clone時對其是一無所知的,它僅僅是簡單地執(zhí)行域?qū)τ虻腸opy,這就是Shallow Clone。
這樣,問題就來了咯,以Employee為例,它里面有一個域hireDay不是基本型別的變量,而是一個reference變量,經(jīng)過Clone之后就會產(chǎn)生一個新的Date型別的reference,它和原始對象中對應(yīng)的域指向同一個Date對象,這樣克隆類就和原始類共享了一部分信息,而這樣顯然是不利的,過程下圖所示:

這個時候我們就需要進行deep Clone了,對那些非基本型別的域進行特殊的處理,例如本例中的hireDay。我們可以重新定義Clone方法,對hireDay做特殊處理,如下代碼所示:
class Employee implements Cloneable
{
public Object clone() throws CloneNotSupportedException
{
Employee cloned = (Employee) super.clone();
cloned.hireDay = (Date) hireDay.clone()
return cloned;
}
}
3. Clone()方法的保護機制
在Object中Clone()是被申明為protected的,這樣做是有一定的道理的,以Employee
類為例,通過申明為protected,就可以保證只有Employee類里面才能“克隆”Employee對象,原理可以參考我前面關(guān)于public、protected、private的學(xué)習(xí)筆記。
4. Clone()方法的使用
Clone()方法的使用比較簡單,注意如下幾點即可:
a. 什么時候使用shallow Clone,什么時候使用deep Clone,這個主要看具體對象的域是什么性質(zhì)的,基本型別還是reference variable
b. 調(diào)用Clone()方法的對象所屬的類(Class)必須implements Clonable接口,否則在調(diào)用Clone方法的時候會拋出CloneNotSupportedException。
希望本篇文章可以幫助到小伙伴們
相關(guān)文章
SpringBoot自定義線程池,執(zhí)行定時任務(wù)方式
這篇文章主要介紹了SpringBoot自定義線程池,執(zhí)行定時任務(wù)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
基于java SSM springboot實現(xiàn)景區(qū)行李寄存管理系統(tǒng)
這篇文章主要介紹了基于java SSM springboot實現(xiàn)的景區(qū)行李寄存管理系統(tǒng),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08
Java數(shù)據(jù)結(jié)構(gòu)與算法之單鏈表深入理解
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)與算法之單鏈表深入理解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09
Kafka 網(wǎng)絡(luò)中斷和網(wǎng)絡(luò)分區(qū)4種場景分析
這篇文章主要介紹了Kafka 網(wǎng)絡(luò)中斷和網(wǎng)絡(luò)分區(qū)4種場景分析2007-02-02
spring項目自定義全局響應(yīng)處理器統(tǒng)一處理響應(yīng)結(jié)果的實現(xiàn)步驟
本文詳細(xì)描述了如何通過@ControllerAdvice和ResponseBodyAdvice在SpringMVC項目中創(chuàng)建自定義響應(yīng)處理器,以及如何使用Wrapper類包裝和標(biāo)準(zhǔn)化返回結(jié)果,感興趣的朋友跟隨小編一起看看吧2025-01-01

