在Java中,子類的構造過程中,必須調用其父類的構造函數,是因為有繼承關系存在時,子類要把父類的內容繼承下來,通過什麼手段做到的?
答案如下:
當你new一個子類對象的時候,必須首先要new一個父類的對像出來,這個父類對象位於子類對象的內部,所以說,子類對象比父類對象大,子類對象裡面包含了一個父類的對象,這是內存中真實的情況.構造方法是new一個對象的時候,必須要調的方法,這是規定,要new父類對象出來,那麼肯定要調用其構造方法,所以:
第一個規則:子類的構造過程中,必須調用其父類的構造方法。一個類,如果我們不寫構造方法,那麼編譯器會幫我們加上一個默認的構造方法,所謂默認的構造方法,就是沒有參數的構造方法,但是如果你自己寫了構造方法,那麼編譯器就不會給你添加了,所以有時候當你new一個子類對象的時候,肯定調用了子類的構造方法,但是在子類構造方法中我們並沒有顯示的調用基類的構造方法,就是沒寫,如:super(); 並沒有這樣寫,但是這樣就會調用父類沒有參數的構造方法,如果父類中沒有沒有參數的構造方法就會出錯。
第二個規則:如果子類的構造方法中沒有顯示的調用基類構造方法,則系統默認調用基類無參數的構造方法注意:如果子類的構造方法中既沒有顯示的調用基類構造方法,而基類中又沒有默認無參的構造方法,則編譯出錯,所以,通常我們需要顯示的:super(參數列表),來調用父類有參數的構造函數。
代碼如下:
//當你沒有使用父類默認的構造方法時,此時在子類的構造方法中就需要顯示的調用父類定義的構造方法。
class Animal{
private String name;
//如果你定義一個新的構造方法
public Animal(String name) {
this.name = name;
}
}
public Dog extends Animal{
//這時你就要顯示的調用父類的構造方法,因為子類默認調用的是父類的
//無參構造方法Animal()
public Dog(){
super("小狗"); //顯示調用父類的有參構造方法
.... //子類的構造方法處理
}
}
//當然,如果你在父類裡面把無參的構造方法,顯示的寫出來了,比如:
class Animal{
private String name;
//無參的構造方法
public Animal() {
..... //處理
}
/*
如果你定義一個新的構造方法,那麼在子類的構造方法中,就可以不用顯示的調用父類的構造方法,因為子類有個無參的構造方法,
子類在構造方法中會自動調用父類已經定義的無參構造方法。
*/
public Animal(String name) {
this.name = name;
}
}
總結:不過一般的,在父類中使用了構造方法的重載,在子類中就可以根據需要,調用相應的父類構造方法。