前言:学完Java回过头来,做一道看起来很普通的题时犯了难!做完之后,发觉还是自己的基础打得不够牢固,所以做此记录!
知识点回顾:
继承的特性:
子类拥有父类非 private 的属性、方法。
子类可以拥有自己的属性和方法,即子类可以对父类进行扩展。
子类可以用自己的方式实现父类的方法。
既然子类拥有父类非 private 的属性、方法。那父类的构造方法呢?
请先看题目:下列代码在编译时提示有错误,请选择哪里出现错误?
class Father {
public Father(int a) {
System.out.println("这是父类的有参构造函数!");
}
}
class Son extends Father {
public Son() {
System.out.println("这是子类的无参构造函数!");
}
public static void main(String[] args) {
Son son = new Son();
}
}
题目分析:
我们知道:
如果父类中没有显式的定义无参构造器,Java也会默认为其自动生成一个无参构造函数,子类的构造器中也会
隐式的调用super()函数
来调用父类的默认无参构造器。
如果父类定义了其他构造器,且仍没有显式的定义无参构造器时,那么父类中的默认无参构造器将会被覆盖,就是说默认的构造器不存在了。
这个时候,子类的构造器将不能找到父类的构造器。找不到父类的构造器就会有错误提示“There is no default constructor available in ‘m1.Father’”
综上所述,父类中的构造方法是不能继承的,但是在实例化子类的时候会调用父类的构造方法。
正确的代码如下:
//第一种:如果父类没有【自定义构造函数】的情况下:
class Father {
public Father() {//这个构造函数写也可以不写,java会默认自动生成
System.out.println("这是父类的无参构造函数!");
}
}
class Son extends Father {
public static void main(String[] args) {
Son son = new Son();
}
}
//父类无参构造函数是否显式定义,子类中无参构造函数是否显式定义,都可以正常运行。
第二种:如果父类自定义了构造函数且没有【显式的定义】无参构造函数时:
class Father {
public Father(int a) {
System.out.println("这是父类的有参构造函数!");
}
}
class Son extends Father {
public Son(int a) {
/** 当父类中没有【显式的定义】无参构造函数时:
* 子类的有参构造器中不能再使用默认的隐式的super()方法。
* 因为隐式的super()调用的还是父类中的无参构造函数,而父类中的无参构造函数已经被覆盖了;
* 这里需要显式的使用super(a)有参的方法,来显式的调用父类的有参构造函数。
* 如果不写super(a)方法会报错。
* */
super(a);
System.out.println("这是子类的有参构造函数!");
}
public static void main(String[] args) {
Son son = new Son(12);
}
}
版权声明:本文为qq_36320053原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。