/*
继承中的构造函数:
子类的实例化过程:
其实在子类的所有构造函数中的第一行,默认都有一行隐式的语句
就是super();也就是说子类的构造函数默认都会访问父类中空参数的构造函数
为什么子类的构造函数都要去默认访问父类的构造函数呢?
因为子类继承了父类,可以访问父类中已有的一些属性。
在子类进行实例化的时候必须要为父类的属性分配空间。
并要进行初始化,所以必须要访问一次父类的构造函数,
看看父类时如何符其属性进行初始化的。
所以子类要实例化对象时,必须要先看父类的初始化过程
结论:父类的构造函数,既可以给本类对象初始化,也可以给子类对象初始化
子类默认的访问父类中的空参构造函数,
注意:如果父类中没有空参数的构造函数,
子类的构造函数必须要手动指定要访问的父类中的构造函数
或者用this来指定访问本类中的构造函数
this和super调用构造函数只能定义构造函数的第一行,不能同时出现。
为什么定义在第一行?因为初始化的动作要先执行.
所有类的父类都是Object
*/
class Fu extends Object
{
int num;
Fu()
{
System.out.println("Fu run!");
}
Fu(int x)
{
System.out.println("fu run!"+x);
}
}
class Zi extends Fu
{
Zi()
{
super();
System.out.println("zi run!");
}
Zi(int x)
{
this();
System.out.println("zi run!"+x);
}
}
class ExtendsDemo4
{
public static void main(String[] args)
{
new Zi();
System.out.println("Hello World!");
}
}