平时写的单独一个类如果没有直接继承父类就是直接继承的Object,有父类就是间接继承的Object,因为父类会继承Object,java的所有类都是Object的子类,哪怕不写super(),也会默认调用的父类的空构造器。
接下来举个例子
代码语言:javascript复制class A{
public A() {
System.out.println("A的无参数构造器");
}
public A(int num) {
System.out.println("A的有参数构造器,参数为:" num);
}
}
class B extends A{
public B() {
System.out.println("B的构造器");
}
}
public class test {
public static void main(String[] args) {
B bb = new B();
}
}
结果是:
A的无参数构造器
B的构造器
也就是子类默认会隐式调用父类的构造器,默认在B构造器第一行添加了super();
接着一个例子:
代码语言:javascript复制class A{
public A() {
System.out.println("A的无参数构造器");
}
public A(int num) {
System.out.println("A的有参数构造器,参数为:" num);
}
}
class B extends A{
public B() {
super(123);
System.out.println("B的构造器");
}
}
public class test {
public static void main(String[] args) {
B bb = new B();
}
}
结果是:
A的有参数构造器,参数为:123
B的构造器
显示调用了父类的构造器,就不会隐式调用空构造器了
最后一个例子:
代码语言:javascript复制class A{
public A(int num) {
System.out.println("A的有参数构造器,参数为:" num);
}
}
class B extends A{
public B() {
System.out.println("B的构造器");
}
}
public class test {
public static void main(String[] args) {
B bb = new B();
}
}
此时A没有空构造器,B也没有显示调用A的构造器,默认隐式调用super A();
但是此时A的空构造器没有定义,所以会报错。
自己在android中也遇到了
这个ArrayAdapter没有空构造器,所以这个super去掉是错误的。
综上所述,如果父类有空构造器,super()可以不写,但如果父类只有含参数的构造器,这个super(...)一定要写,并且要对应父构造器的参数,否则就会报错!