詳解super關鍵字

在Java中,子類的構造過程中,必須調用其父類的構造函數,是因爲有繼承關係存在時,子類要把父類的內容繼承下來,通過什麼手段做到的?   

答案如下:   

 當你new一個子類對象的時候,必須首先要new一個父類的對象出來,這個父類對象位於子類對象的內部,所以說,子類對象比父類對象大,子類對象裏面包含了一個父類的對象,這是內存中真實的情況.構造方法是new一個對象的時候,必須要調的方法,這是規定,要new父類對象出來,那麼肯定要調用其構造方法,所以:   

 第一個規則:子類的構造過程中,必須調用其父類的構造方法。一個類,如果我們不寫構造方法,那麼編譯器會幫我們加上一個默認的構造方法,所謂默認的構造方法,就是沒有參數的構造方法,在默認的構造方法中又會去默認的調用父類的默認的構造方法,但是如果你自己寫了構造方法,那麼編譯器就不會給你添加了,所以有時候當你new一個子類對象的時候,肯定調用了子類的構造方法,但是在子類構造方法中我們並沒有顯示的調用基類的構造方法,就是沒寫,如:super(); 並沒有這樣寫,但是這樣就會調用父類沒有參數的構造方法,如果父類中沒有沒有參數的構造方法就會出錯。

 第二個規則:如果子類的構造方法中沒有顯示的調用基類構造方法,則系統默認調用基類無參數的構造方法注意:如果子類的構造方法中既沒有顯示的調用基類構造方法,而基類中又沒有默認無參的構造方法,則編譯出錯,所以,通常我們需要顯示的:super(參數列表),來調用父類有參數的構造函數。

class GrandFather {

GrandFather(int a) {
		System.out.println("I am GrandFather! " + a);
	}
}


class Father extends GrandFather {
	Father() {
		// 必須顯示調用父類帶參數的構造方法,否則編譯報錯
		super(5);
		System.out.println("I am Father!");
	}
}


class Son extends Father {
	Son() {
		System.out.println("I am son!");
	}
}


public class ExtendsDemo {
	public static void main(String[] args) {
		new Son();
	}
}
打印結果:

I am GrandFather! 5
I am Father!
I am son!


那麼爲什麼子類必須調用父類的構造方法呢?

因爲子類繼承了父類,那麼就默認的含有父類的公共成員方法和公共成員變量,這些方法和變量在子類裏不再重複聲明。如果你初始化子類的時候,不初始化父類,那麼你通過子類調用父類方法或變量的時候就會拋出異常!並且從上面的例子可以看出,這種初始化的過程是從“基類向外擴散的”。



發佈了39 篇原創文章 · 獲贊 24 · 訪問量 12萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章