子父类中的构造函数的特点
在子类构造对象时,发现,访问子类构造函数时,父类也运行了。这是因为在子类的构造函数中第一行有一个默认的隐式语句—— super();
子类的实例化过程:子类中所有的构造函数默认都会访问父类中的空参数的构造函数。
为什么子类实例化的时候要访问父类中的构造函数呢?
那是因为子类继承了父类,获取到了父类中内容(属性),所以在使用父类内容之前, 要先看父类是如何对自己的内容进行初始化的。 所以子类在构造对象时,必须访问父类中的构造函数。
如果父类中没有定义空参数构造函数,那么子类的构造函数必须用super明确要调用 父类中哪个构造函数。同时子类构造函数中如果使用this调用了本类构造函数时, 那么super就没有了,因为super和this都只能定义第一行。所以只能有一个。 但是可以保证的是,子类中肯定会有其他的构造函数访问父类的构造函数。
注意
supre语句必须要定义在子类构造函数的第一行。因为父类的初始化动作要先完成。
package com.Tips;
abstract class p1{
int num;
p1(){
num = 10;
System.out.println("无参构造函数p1——"+num);
}
p1(int n){
num = n;
System.out.println("有参构造函数p1——"+num);
}
}
class p2 extends p1{
int num;
p2(){
//隐式语句—— super()
System.out.println("无参构造函数p2——"+num);
}
p2(int num){
super(2);
// super();
this.num = num;
System.out.println("有参构造函数p2——"+num);
}
public static void main(String[] args) {
new p2(11);
}
}