子类实例化执行子类的构造函数时,子类构造函数方法体的第一行会有一个隐藏 super(); 来执行父类的无参构造函数。
若父类中没有定义一个无参构造函数,则子类必须用super( );明确指定调用父类的哪一个构造函数。且super( );必须在子类构造函数的第一行。
class Fu
{
Fu()
{
System.out.println("Fu run");
}
}
class Zi extends Fu
{
Zi()
{
//super(); 这里会有一个默认的隐式语句来初始化父类。
//也可以添加super();来自己执行父类构造函数,此时可添加参数。
System.out.println("Zi run");
}
}
class Demo
{
public static void main(String[] args)
{
new Zi();
}
}
//另1:构造函数不存在覆盖,因子类名不可能与父类名相同
// 且构造函数不继承
另2
下面这种情况下
因this( )关键字也需要放在第一行,所以当在一个构造函数中第一行放了一个this( )时,super( )就没有了,下面代码实例化执行过程为
new Zi(3)——执行Zi(3)——执行this()——执行Zi()——执行super()
——执行父类的无参构造函数
——执行Zi( )中的System.out.println(“Zi run”);并执行隐藏的return ;
——执行Zi(int num)中的System.out.println(num);并执行隐藏的return;
另3:进入死循环姿势:
在Zi()第一行添加this( 0 );
class Fu
{}
class Zi extends Fu
{
Zi()
{
//super(); 默认的隐式语句。
System.out.println("Zi run");
}
Zi(int num)
{
this();
System.out.println(num);
}
}
最后一个另
默认构造函数也不是啥也没干的
JAVA中所有的类都直接或间接继承于Object类
所以 class Demo //后面隐藏了 extends Object
class Demo
{
/*默认的构造函数
Demo()
{
super();
return;
}
*/
}
绝对最后一个另:
Object就是真的没有父类了