在对子类对象进行初始化时,父类的构造函数也会运行,那是因为子类的构造函数默认第一行有一条隐式的语句super();而父类中如果没有自定义的构造函数,那么会有默认的空参数构造函数,而父类如果自定义了带参数的构造函数,那么就不存在默认的空参函数了,而子类在默认调用super( )时找不到父类的空参构造函数,那么会报错。如果父类自定义了带参构造函数,那么子类初始化时必须要调用该带参数的构造函数。
子类一定要访问父类中的构造函数,因为父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的,所以子类在对象初始化时 ,要先访问一下父类中的构造函数,如果要访问父类中指定的构造函数,可以通过手动定义super语句的方式来指定。
注意:super语句一定要定义在子类构造函数的第一行。
子类的实例化过程:
结论: 子类的所有的构造函数,默认都会访问父类中空参数的构造函数,因为子类每一个构造函数内的第一行都有一句隐式super();
当父类中没有空参数的构造函数时,子类必须手动通过super语句形式来指定要访问父类中的构造函数。
当然,子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数。子类中至少会有一个构造函数会访问父类中的构造函数。
毕老师的基础视频第7天讲的很清楚,建议你再仔细学习巩固一下 |