在子类构造对象时,发现,访问子类构造函数时父类也运行了。
class Fu{
Fu(){
System.out.println("fu run")
}
}
class Zi extends Fu{
Zi(){
super();//默认
System.out.println("zi run");
}
}
原因是:在子类的构造函数中第一行有一个默认的隐式语句。super();
子类实例化过程:子类中所有的构造函数默认都会访问父类中的空参数的构造函数
class Fu{
Fu(){
System.out.println("A fu run");
}
}
Fu(int x){
System.out.println("B fu run ");
}
class Zi{
Zi(){
super();//隐式语句
System.out.println("D zi run");
}
}
Zi zi=new Zi();
输出的是 A 和 D
为什么子类实例化要先访问父类的构造方法?
那时因为子类继承了父类,获取到了父类中的内容(属性),所以在使用父类内容之前要先看父类是如何对自己的内容进行初始化
所以子类在构造对象时,必须访问父类中的构造函数
为了完成这个必须动作,就在子类的构造函数中加入了super().语句
如果父类中没有定义空参构造函数,那么子类的构造函数必须使用super明确要调用父类中的哪个构造方法。同时子类构造函数中如果使用this();调用了本类的构造函数时,那么super就没有了,因为super和this()都只能定义在第一行,所以只能有一个。但是可以保证的是,子类中肯定会有其他的构造函数访问父类的构造函数。
class Zi{
Zi(){
System.out.println();
}
Zi(int x){
this();
System.out.println();
}
}
那么就由子类的空参函数去访问父类的构造函数。
注意:super语句必须要定义在子类构造函数的第一行,因为父类的初始化动作要先完成。