經常聽到有人說java中沒有指針。事實如此嗎?no,java是有指針的,只不過換了個名字而已,也就是我們經常提到的引用。我們知道,在Java中一切都是對象,那麼我們如何操控對象?如何在成千上萬的對象中找到我們所需的那個對象呢?又是如何讓對象按照我們的意思來完成任務的呢?
Objecto=newObject();
這是Java中最常見的語句了,在這句話中做了三件事。首先聲明一個Object類型的變量o,在內存中為對象劃分一塊地址newObject(),將聲明的變量指向內存中的對象。如此一來,我們就可以通過o來操縱對象了。就好像孩子們玩的遙控飛機,在空中飛行的是飛機,而使它做出優美動作的卻是孩子們手中的搖控器。
"克隆"是如今聽到的較多的詞匯,聽說已經將某只羊克隆了好幾份了。但願這種技術不要在人身上實驗。Java中也有"克隆",與現實世界的克隆一樣,將一個實際存在的對象拷貝幾份。如下:
//倒霉的羊
publicclassSheepimplementsCloneable{
privateStringname;
publicvoidsetName(Stringarg){
name=arg;
}
publicStringgetName(){
returnname;
}
publicObjectclone()throwsCloneNotSupportedException{
returnsuper.clone();
}
}
//克隆
publicclassMain{
publicstaticvoidmain(String[]args)throwsCloneNotSupportedException{
Sheepsheep=newSheep();//先得到那只羊的實例
sheep.setName("我是真的");//給它做個記號
System.out.println("sheep.getName()="+sheep.getName());
SheepsheepClone=(Sheep)sheep.clone();//開始克隆
System.out.println("sheepClone.getName()="+sheepClone.getName());
}
}
運行程序結果為:
sheep.getName()=我是真的
sheepClone.getName()=我是真的
兩只羊是一模一樣的(哪怕那只羊瘸腿)。讓我們來看看代碼。首先要注意的是Sheep類實現了Cloneable接口(該接口屬於java.lang包,默認已經導入了),該接口中並沒有定義要實現的方法,是個空接口,起標志作用。也就是說,實現了這個接口的羊就不再是只普通的羊,它是一只可以被克隆的羊。再往下看,有個clone方法,返回Object類型的對象,並拋出CloneNotSupportedException異常。該方法覆寫了父類(Object)的clone方法,並在最後調用了super.clone(),這也意味著無論clone類繼承結構是什麼樣的,super.clone()都會直接或間接調用Object類的clone()方法。看看jdk幫助文檔會發現,Object類的clone()是一個native方法,我們知道,native方法的效率一般來說都是遠高於Java中的非native方法。這也說明了new一個對象,然後將原對象中的數據導入到新創建的對象中去的做法是多麼愚蠢。必須說明的是Object中的clone方法是protected的,所以要使用clone就必須繼承Object類(默認)。並且為了可以使其它類調用該方法,必須將其作用域設置為public。
以上只是一個簡單clone的實現。明天說說"影子clone"和"深度clone"。
夜,深了。