Java中子類(lèi)調(diào)用父類(lèi)構(gòu)造方法的問(wèn)題分析
在Java中,子類(lèi)的構(gòu)造過(guò)程中,必須調(diào)用其父類(lèi)的構(gòu)造函數(shù),是因?yàn)橛欣^承關(guān)系存在時(shí),子類(lèi)要把父類(lèi)的內(nèi)容繼承下來(lái),通過(guò)什么手段做到的?
答案如下:
當(dāng)你new一個(gè)子類(lèi)對(duì)象的時(shí)候,必須首先要new一個(gè)父類(lèi)的對(duì)像出來(lái),這個(gè)父類(lèi)對(duì)象位于子類(lèi)對(duì)象的內(nèi)部,所以說(shuō),子類(lèi)對(duì)象比父類(lèi)對(duì)象大,子類(lèi)對(duì)象里面包含了一個(gè)父類(lèi)的對(duì)象,這是內(nèi)存中真實(shí)的情況.構(gòu)造方法是new一個(gè)對(duì)象的時(shí)候,必須要調(diào)的方法,這是規(guī)定,要new父類(lèi)對(duì)象出來(lái),那么肯定要調(diào)用其構(gòu)造方法,所以:
第一個(gè)規(guī)則:子類(lèi)的構(gòu)造過(guò)程中,必須調(diào)用其父類(lèi)的構(gòu)造方法。一個(gè)類(lèi),如果我們不寫(xiě)構(gòu)造方法,那么編譯器會(huì)幫我們加上一個(gè)默認(rèn)的構(gòu)造方法,所謂默認(rèn)的構(gòu)造方法,就是沒(méi)有參數(shù)的構(gòu)造方法,但是如果你自己寫(xiě)了構(gòu)造方法,那么編譯器就不會(huì)給你添加了,所以有時(shí)候當(dāng)你new一個(gè)子類(lèi)對(duì)象的時(shí)候,肯定調(diào)用了子類(lèi)的構(gòu)造方法,但是在子類(lèi)構(gòu)造方法中我們并沒(méi)有顯示的調(diào)用基類(lèi)的構(gòu)造方法,就是沒(méi)寫(xiě),如:super(); 并沒(méi)有這樣寫(xiě),但是這樣就會(huì)調(diào)用父類(lèi)沒(méi)有參數(shù)的構(gòu)造方法,如果父類(lèi)中沒(méi)有沒(méi)有參數(shù)的構(gòu)造方法就會(huì)出錯(cuò)。
第二個(gè)規(guī)則:如果子類(lèi)的構(gòu)造方法中沒(méi)有顯示的調(diào)用基類(lèi)構(gòu)造方法,則系統(tǒng)默認(rèn)調(diào)用基類(lèi)無(wú)參數(shù)的構(gòu)造方法注意:如果子類(lèi)的構(gòu)造方法中既沒(méi)有顯示的調(diào)用基類(lèi)構(gòu)造方法,而基類(lèi)中又沒(méi)有默認(rèn)無(wú)參的構(gòu)造方法,則編譯出錯(cuò),所以,通常我們需要顯示的:super(參數(shù)列表),來(lái)調(diào)用父類(lèi)有參數(shù)的構(gòu)造函數(shù)。
//當(dāng)你沒(méi)有使用父類(lèi)默認(rèn)的構(gòu)造方法時(shí),此時(shí)在子類(lèi)的構(gòu)造方法中就需要顯示的調(diào)用父類(lèi)定義的構(gòu)造方法。
class Animal{
private String name;
//如果你定義一個(gè)新的構(gòu)造方法
public Animal(String name) {
this.name = name;
}
}
public Dog extends Animal{
//這時(shí)你就要顯示的調(diào)用父類(lèi)的構(gòu)造方法,因?yàn)樽宇?lèi)默認(rèn)調(diào)用的是父類(lèi)的
//無(wú)參構(gòu)造方法Animal()
public Dog(){
super("小狗"); //顯示調(diào)用父類(lèi)的有參構(gòu)造方法
.... //子類(lèi)的構(gòu)造方法處理
}
}
//當(dāng)然,如果你在父類(lèi)里面把無(wú)參的構(gòu)造方法,顯示的寫(xiě)出來(lái)了,比如:
class Animal{
private String name;
//無(wú)參的構(gòu)造方法
public Animal() {
..... //處理
}
/*
如果你定義一個(gè)新的構(gòu)造方法,那么在子類(lèi)的構(gòu)造方法中,就可以不用顯示的調(diào)用父類(lèi)的構(gòu)造方法,因?yàn)樽宇?lèi)有個(gè)無(wú)參的構(gòu)造方法,
子類(lèi)在構(gòu)造方法中會(huì)自動(dòng)調(diào)用父類(lèi)已經(jīng)定義的無(wú)參構(gòu)造方法。
*/
public Animal(String name) {
this.name = name;
}
}
總結(jié):不過(guò)一般的,在父類(lèi)中使用了構(gòu)造方法的重載,在子類(lèi)中就可以根據(jù)需要,調(diào)用相應(yīng)的父類(lèi)構(gòu)造方法。
相關(guān)文章
spring boot搭建文件服務(wù)器解決同時(shí)上傳多個(gè)圖片和下載的問(wèn)題
這篇文章主要介紹了spring boot搭建文件服務(wù)器解決同時(shí)上傳多個(gè)圖片和下載的問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11Spring MVC之@RequestMapping注解詳解
本篇文章主要介紹了Spring MVC之@RequestMapping 詳解,RequestMapping是一個(gè)用來(lái)處理請(qǐng)求地址映射的注解,可用于類(lèi)或方法上。有興趣的可以了解一下。2017-01-01Java+Appium實(shí)現(xiàn)屏幕錄制功能
這篇文章主要介紹了Java如何利用Appium實(shí)現(xiàn)屏幕錄制功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06四個(gè)Java常見(jiàn)分布式鎖的選型和性能對(duì)比
當(dāng)涉及到分布式系統(tǒng)中的并發(fā)控制和數(shù)據(jù)一致性時(shí),分布式鎖是一種常見(jiàn)的解決方案,本文將對(duì)幾種常見(jiàn)的分布式鎖實(shí)現(xiàn)原理、實(shí)現(xiàn)示例、應(yīng)用場(chǎng)景以及優(yōu)缺點(diǎn)進(jìn)行詳細(xì)分析,需要的可以參考一下2023-05-05SpringBoot深入刨析數(shù)據(jù)層技術(shù)
這篇文章主要介紹了SpringBoot數(shù)據(jù)層技術(shù)的解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08java.lang.UnsatisfiedLinkError: %1 不是有效的Win32應(yīng)用程序錯(cuò)誤解決
這篇文章主要給大家介紹了關(guān)于java.lang.UnsatisfiedLinkError: %1 不是有效的Win32應(yīng)用程序錯(cuò)誤的解決方法,文中介紹的非常詳細(xì),需要的朋友們可以參考學(xué)習(xí),下面來(lái)一起看看吧。2017-03-03