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