子類實例化時,默認調用父類的無參構造方法(不管子類的構造器有沒有參數,因為子類繼承的是父類的屬性和方法,只調用父類的無參構造器就可以繼承父類的屬性和方法,因此不會調用父類的有參構造器),再調用子類的有參/無參構造器。
示例:
package classTest; class Father { public Father(){ System.out.println("父類的無參構造方法"); } public Father(int a ) { System.err.println("父類的有參構造方法"+a); } } class Son extends Father{ public Son() { System.out.println("子類中的無參構造方法"); } public Son(int a ) { System.out.println("子類中的有參構造方法"+a); } } public class TestExecute { public static void main(String[] args) { Son s = new Son(); System.out.println("---------------"); Son a = new Son(5); } }
結果:
父類的無參構造方法
子類中的無參構造方法
---------------
父類的無參構造方法
子類中的有參構造方法5
補充知識:JAVA父類和子類的構造函數之間的關系
我就廢話不多說了,大家還是直接看代碼吧~
class SuperClass { private int n; SuperClass(){ //父類的無參構造器 System.out.println("SuperClass()"); } SuperClass(int n) { //父類的帶參構造器 System.out.println("SuperClass(int n)"); this.n = n; } } class SubClass extends SuperClass{ private int n; SubClass(){ //子類的無參構造器 super(300);//調用父類的帶參構造器,super(300)相當于SuperClass(300) System.out.println("SubClass"); } public SubClass(int n){ //子類的帶參構造器 System.out.println("SubClass(int n):"+n); this.n = n; } } public class TestSuperSub{ public static void main (String args[]){ SubClass sc = new SubClass(); SubClass sc2 = new SubClass(200); } }
這個實例的輸出結果是:
SuperClass(int n) SubClass SuperClass() SubClass(int n):200
從這個實例得到的結果是(個人見解):子類在構造時,會根據主函數中是否傳入參數來選擇使用無參構造器 or帶參構造器,在這個實例中:
當子類調用的是無參構造器時,若父類的構造器是帶有參數的,則必須在子類的構造器中顯式地通過super關鍵字調用父類的構造器并配以適當的參數列表。
當子類調用的是帶參構造器時,則在子類的構造器中用super調用父類構造器不是必須的,如果沒有使用super關鍵字,系統會自動調用父類的無參構造器。
以上這篇Java子類實例化總是默認調用父類的無參構造操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。