黑马程序员—继承中构造函数的特点

时间:2023-01-30 00:42:57
    子类的实例化过程:

1、子类的构造函数第一条:隐式的super();

      注意:当父类中没有空参数的构造函数时,要访问父类中指定的构造函数,

必须通过手动定义super();语句来指定要访问父类中哪个构造函数。

2、子类一定要访问父类中的构造函数的原因

      通过继承,父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的,所以要先访问父类中的构造函数。

    

    特点:

super();必须在构造函数的第一行

 class Fu
{
int num;
Fu()
{
num = 60;//子类需考虑父类在构造函数中对数据进行哪些操作
//所以子类要通过super();先访问父类中的构造函数
System.out.println("fu run");
}
}
class Zi extends Fu
{
Zi()
{
//super();隐式
//注意:当父类没有空参数的构造函数,
//子类必须手动指定要访问哪个构造函数super(4);
System.out.println("zi run");
}
Zi(int x)
{
//super();隐式
System.out.println("zi run"+x);
}

}
class ExtendsDemo
{
public static void main(String[] args)
{
Zi z1 = new Zi();
Zi z2 = new Zi(4);
}
}


    结论:子类中所有的构造函数默认都会访问空参数中的构造函数
        因为子类每一个构造函数内的第一行都有一句隐式的super();或者自定义的super();语句
        当然,子类的构造函数也可以手动指定this语句来访问本类中的构造函数,但是子类中至少会有一个构造函 数会访问父类中的构造函数