您能帮我理解为什么以下代码会导致编译错误吗?如果我删除Foo2的构造函数,它将正常工作。
class Foo2 {
int st;
protected Foo2(int initialVal) {
this.st = initialVal;
}
}
public class Main extends Foo2 {
int st;
private Main(int initialVal) {
this.st = initialVal;
}
public static void main(String args[]) {
Foo2 f = new Main(2);
}
}
Main
类的构造函数隐式调用super()
。但是,由于您的Foo2
类具有带参数的构造函数,因此编译器不会为其生成没有参数的构造函数,因此隐式super()
调用无效。
您可以通过删除现有的Foo2
构造函数(如您所做的操作)或向Foo2
添加第二个(无参数)构造函数或将super(someIntValue);
调用作为Main
的第一条语句来解决此问题。构造函数。
这里是第三种选择:
private Main(int initialVal) {
super(initialVal);
this.st = initialVal;
}
当然,在超类st
和子类Foo2
中都没有Main
实例变量。
private Main(int initialVal) {
super(initialVal);
}
会更有意义。
默认情况下,如果尚未添加,编译器将在子类构造函数中添加super()
因此,在您的情况下,父类具有单个参数化构造函数,因此将无法使用super()
进行调用>
所以您必须致电super(initialVal)
使其生效
如果不添加super(initialVal)
,则必须创建默认构造函数在不带参数的父类中,因此可以通过super()
进行调用,该编译器将添加它