子类调用父类构造器《转载》

有时我们在写子类的时候会出现如下所示的报错:
Implicit super constructor AbstractClass() is undefined for default constructor. Must define an explicit constructor
在子类继承父类的时候,实例化时java编译器是会首先调用父类的构造函数,然后调用子类的构造函数的,这也就意味着,如果
父类没有默认构造函数的话,在子类的构造函数中第一行必须显式调用父类的构造函数,否则的会是报编译错误的。

java继承中对构造函数是不继承的,只是调用(隐式或显式)。

以下是例子:

 public class FatherClass {

 public FatherClass() {
       System.out.println(100);
 }

 public FatherClass(int age) {
      System.out.println(age);
 }

}

 

public class SonClass extends FatherClass{

        public SonClass() {
         }

        
public SonClass(int c) {
                 System.out.println(1234);
        }
   
 public static void main(String[] args) {

  SonClass s = new SonClass(66);
 
 }
}

编译后执行结果如下是什么呢?

分析:SonClass s = new SonClass(66);执行这句时,调用

 public SonClass(int c) {
                 System.out.println(1234);//系统会自动先调用父类的无参构造函数(super())
        }

 

在这个构造函数中,等价于

 public SonClass(int c) {

                super();//必须是第1行,否则不能编译
                 System.out.println(1234);
        }

所以结果是    100
             
1234

在创建子类的对象时,Java虚拟机首先执行父类的构造方法,然后再执行子类的构造方法。在多级继承的情况下,将从继承树的最上层的父类开始,依次执行各个类的构造方法,这可以保证子类对象从所有直接或间接父类中继承的实例变量都被正确地初始化。

3.如果子类构造函数是这样写的

public SonClass(int c) {

                super(22);//必须是第1行,否则不能编译
                          
//显式调用了super后,系统就不再调用无参的super()了;
                 System.out.println(1234);
        }

执行结果是   22
            1234

总结1:构造函数不能继承,只是调用而已。

如果父类没有无参构造函数

创建子类时,不能编译,除非在构造函数代码体中第一行,必须是第一行显式调用父类有参构造函数

如下:

SonClass (){

super(777);//显示调用父类有参构造函数

System.out.println(66);

}

如果不显示调用父类有参构造函数,系统会默认调用父类无参构造函数super();

但是父类中没有无参构造函数,那它不是不能调用了。所以编译就无法通过了。

总结2:创建有参构造函数后,系统就不再有默认无参构造函数。

如果没有任何构造函数,系统会默认有一个无参构造函数。

猜你喜欢

转载自liuzhiqiang19890403.iteye.com/blog/2102206