什么是"clone"?
在實(shí)際編程過程中,我們常常要遇到這種情況:有一個(gè)對(duì)象A,在某一時(shí)刻A中已經(jīng)包含了一些有效值,此時(shí)可能 會(huì)需要一個(gè)和A完全相同新對(duì)象B,并且此后對(duì)B任何改動(dòng)都不會(huì)影響到A中的值,也就是說,A與B是兩個(gè)獨(dú)立的對(duì)象,但B的初始值是由A對(duì)象確定的。在 Java語(yǔ)言中,用簡(jiǎn)單的賦值語(yǔ)句是不能滿足這種需求的。要滿足這種需求雖然有很多途徑,但實(shí)現(xiàn)clone()方法是其中最簡(jiǎn)單,也是最高效的手段。
Java的所有類都默認(rèn)繼承java.lang.Object類,在java.lang.Object類中有一個(gè)方法clone()。JDK API的說明文檔解釋這個(gè)方法將返回Object對(duì)象的一個(gè)拷貝。要說明的有兩點(diǎn):一是拷貝對(duì)象返回的是一個(gè)新對(duì)象,而不是一個(gè)引用。二是拷貝對(duì)象與用 new操作符返回的新對(duì)象的區(qū)別就是這個(gè)拷貝已經(jīng)包含了一些原來對(duì)象的信息,而不是對(duì)象的初始信息。
怎樣應(yīng)用clone()方法?
一個(gè)很典型的調(diào)用clone()代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
|
class CloneClass implements Cloneable{ public int aInt; public Object clone(){ CloneClass o = null ; try { o = (CloneClass) super .clone(); } catch (CloneNotSupportedException e){ e.printStackTrace(); } return o; } } |
有三個(gè)值得注意的地方,一是希望能實(shí)現(xiàn)clone功能的CloneClass類實(shí)現(xiàn)了Cloneable接口,這個(gè)接口屬于java.lang 包,java.lang包已經(jīng)被缺省的導(dǎo)入類中,所以不需要寫成java.lang.Cloneable。另一個(gè)值得請(qǐng)注意的是重載了clone()方 法。最后在clone()方法中調(diào)用了super.clone(),這也意味著無論clone類的繼承結(jié)構(gòu)是什么樣的,super.clone()直接或 間接調(diào)用了java.lang.Object類的clone()方法。下面再詳細(xì)的解釋一下這幾點(diǎn)。
應(yīng)該說第三點(diǎn)是最重要的,仔細(xì) 觀察一下Object類的clone()一個(gè)native方法,native方法的效率一般來說都是遠(yuǎn)高于java中的非native方法。這也解釋了為 什么要用Object中clone()方法而不是先new一個(gè)類,然后把原始對(duì)象中的信息賦到新對(duì)象中,雖然這也實(shí)現(xiàn)了clone功能。對(duì)于第二點(diǎn),也要 觀察Object類中的clone()還是一個(gè)protected屬性的方法。這也意味著如果要應(yīng)用clone()方法,必須繼承Object類,在 Java中所有的類是缺省繼承Object類的,也就不用關(guān)心這點(diǎn)了。然后重載clone()方法。還有一點(diǎn)要考慮的是為了讓其它類能調(diào)用這個(gè)clone 類的clone()方法,重載之后要把clone()方法的屬性設(shè)置為public。
那么clone類為什么還要實(shí)現(xiàn) Cloneable接口呢?稍微注意一下,Cloneable接口是不包含任何方法的!其實(shí)這個(gè)接口僅僅是一個(gè)標(biāo)志,而且這個(gè)標(biāo)志也僅僅是針對(duì) Object類中clone()方法的,如果clone類沒有實(shí)現(xiàn)Cloneable接口,并調(diào)用了Object的clone()方法(也就是調(diào)用了 super.Clone()方法),那么Object的clone()方法就會(huì)拋出CloneNotSupportedException異常。
以上是clone的最基本的步驟,想要完成一個(gè)成功的clone,還要了解什么是"影子clone"和"深度clone"。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!