在JAVA中,一個類可以有多個構建器,如果寫了多個構建器,通常需要在一個構建器中調用另一個構建器來避免重複代碼,此時,“this”關鍵字可以做到對同一對象的多個構建器進行明確的調用。“this”只能在方法內部調用,可爲已經調用了此方法的該對象生成相應的句柄。接下來看一段代碼:
import java.util.*;
public class Flower {
int petalCount = 0;
String s = new String("null");
Flower(int petals){
petalCount = petals;
System.out.println("Constructor w/int arg only,petalCount="+petalCount);
}
Flower(String ss){
System.out.println("Constructor w/String arg only,s="+ss);
s=ss;
}
Flower(String ss,int petals){
this(petals);
//this(s);
this.s = s;
System.out.println("String & int args");
}
Flower(){
this("hi",45);
System.out.println("default constructor(no args)");
}
void print(){
//this(11);
System.out.println("petalCount="+petalCount+"s="+s);
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Flower x = new Flower();
x.print();
}
}
該程序的運行結果爲:
首先,簡單解釋該程序,主函數中生成一個Flower對象x,在生成該對象x的過程中,編譯器自動調用默認的構建器Flower(),在這裏我們重寫了Flower()函數,加入了“this”,使得程序再次調用Flower(int petals)函數,可以看到輸出結果符合調用的順序。
在一個類的衆多構建器當中,構建器Flower(String s,int petals)中可以看到一個問題:儘管可以用“this”調用一個構建器,但不能調用兩個,並且構建器的調用必須首要完成,不可放到第二步或第三步,否則編譯器會報錯。同時可以看到“this“的另一個用途:由於自變量s的名字與成員數據s的名字重複,爲避免混淆,可以採用this.s來引用成員數據。
在print()函數中,可以看到:編譯器不允許在另一個方法內部調用構建器,只允許在一個構建器內調用另一個構建器。
然而在static(靜態)方法中,“this”並不存在,不可以從static方法內部發出對非static方法的調用,但可以從非static方法內部發出對static方法的調用,並且在沒有任何對象的前提下,我們便可以對類本身發出對static方法的調用,這也是static方法存在的意義所在。