子父类中构造函数的特点
在子类构造对象时 发现 访问 子类构造函数时 父类也运行了 为什么呢?
原因是:
在子类的构造函数中的第一行有一个默认的隐式语句:super();//调用的就是父类中的空参数的构造函数
子类的实例化过程:子类中所有的构造函数默认都会访问父类中的空参数的构造函数
class Fu
{
Fu()
{
System.out.println("Fu");
}
}
class Zi extends Fu
{
Zi()
{
//super(); 默认隐式语句,调用的就是父类中的空参数的构造函数。,也可调用非空的,
//但是需要在父类构造函数中加参数,此处super(参数)
System.out.println("Zi");
//隐藏了return;
}
}
注意:构造函数不能覆盖,构造函数没有继承,单用super()实现。叫子类的实例化过程。
子类的实例化过程:
子类中所有的构造函数默认都会访问父类中的空参数的构造函数
为什么子类实例化的时候要访问父类中的构造函数呢?
那是因为子类继承了父类 获取到了父类中的内容(属性)所以在使用父类内容之前 要先看父类是如何对自己的内容初始化的 所以子类在构造对象时 必须访问父类中的构造函数
为了完成这个必须的动作 就在子类的构造函数中加入了super()语句
如果父类中没有定义空参数构造函数,那么子类的构造函数必须用super明确要调用父类中哪个构造函数,同时子类构造函数中如果使用this调用了本类构造函数时,那么super就没有了,因为super和this都只能定义在第一行,但是this()调用会调用其它子类构造函数,其中也会有super()。结果是至少有一个子类构造函数调用到super()。
注意:super语句必须要定义在子类构造函数的第一行 因为父类的初始化动作要先完成
每个类中都隐藏了一下代码
class Demo
{
/*
Demo()
{
super();
return;
}*/
}
注意:
1、构造函数的权限和类一致,如果类为public,那么构造函数默认为public类,若为其它,则也默认为其它。
2、jav