Java子类实例化总是默认调用父类的无参构造操作
子类实例化时,默认调用父类的无参构造方法(不管子类的构造器有没有参数,因为子类继承的是父类的属性和方法,只调用父类的无参构造器就可以继承父类的属性和方法,因此不会调用父类的有参构造器),再调用子类的有参/无参构造器。
示例:
packageclassTest; classFather{ publicFather(){ System.out.println("父类的无参构造方法"); } publicFather(inta){ System.err.println("父类的有参构造方法"+a); } } classSonextendsFather{ publicSon(){ System.out.println("子类中的无参构造方法"); } publicSon(inta){ System.out.println("子类中的有参构造方法"+a); } } publicclassTestExecute{ publicstaticvoidmain(String[]args){ Sons=newSon(); System.out.println("---------------"); Sona=newSon(5); } }
结果:
父类的无参构造方法
子类中的无参构造方法
---------------
父类的无参构造方法
子类中的有参构造方法5
补充知识:JAVA父类和子类的构造函数之间的关系
我就废话不多说了,大家还是直接看代码吧~
classSuperClass{ privateintn; SuperClass(){//父类的无参构造器 System.out.println("SuperClass()"); } SuperClass(intn){//父类的带参构造器 System.out.println("SuperClass(intn)"); this.n=n; } } classSubClassextendsSuperClass{ privateintn; SubClass(){//子类的无参构造器 super(300);//调用父类的带参构造器,super(300)相当于SuperClass(300) System.out.println("SubClass"); } publicSubClass(intn){//子类的带参构造器 System.out.println("SubClass(intn):"+n); this.n=n; } } publicclassTestSuperSub{ publicstaticvoidmain(Stringargs[]){ SubClasssc=newSubClass(); SubClasssc2=newSubClass(200); } }
这个实例的输出结果是:
SuperClass(intn) SubClass SuperClass() SubClass(intn):200
从这个实例得到的结果是(个人见解):子类在构造时,会根据主函数中是否传入参数来选择使用无参构造器or带参构造器,在这个实例中:
当子类调用的是无参构造器时,若父类的构造器是带有参数的,则必须在子类的构造器中显式地通过super关键字调用父类的构造器并配以适当的参数列表。
当子类调用的是带参构造器时,则在子类的构造器中用super调用父类构造器不是必须的,如果没有使用super关键字,系统会自动调用父类的无参构造器。
以上这篇Java子类实例化总是默认调用父类的无参构造操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。