第一:子类的构造过程中必须调用其基类的构造方法
第二:如果子类的构造方法中没有显示地调用基类的构造方法,则系统默认调用基类
无参数的构造方法
第三:如果子类构造方法中既没有显式调用基类的构造方法,而基类中有没有无参数的构造方法,则编译出错
package mashibing;
public class TextSupSub {
/** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub SubClass sc1 = new SubClass(); SubClass sc2 = new SubClass(400);
}
}
class SuperClass { private int n; SuperClass() { System.out.println("SuperClass()"); this.n = n; } SuperClass(int n) { System.out.println("SuperClass("+n+")"); } }
class SubClass extends SuperClass { private int n; SubClass(int n) { System.out.println("SubClass("+n+")"); } SubClass() { super(300);//必须写到第一句 System.out.println("SubClass()"); }}
首先看这个程序main中的SubClass sc1 = new SubClass();很显然其调用了子类SubClass中的SubClass()方法,
注意该方法的第一句就调用了父类SupClass的SupClass(int n)方法;这一点很好理解。但如果把super(300)给注释掉或者去掉,此时运行的结果第一句就是SuperClass(),也就是符合第二条规则。其实此时子类的
SubClass() { super(300);//把这一句去掉 System.out.println("SubClass()"); }就相当于
SubClass() { super();//调用了基类中无参数的构造方法 System.out.println("SubClass()"); }
如果去掉此句的同时把基类的SupClass()也给去掉,则就符合第三条规则了,运行一定出错。
同理分析可知子类中的这一方法: SubClass(int n) { System.out.println("SubClass("+n+")"); } 就等同于
SubClass(int n) {
SupClss(); System.out.println("SubClass("+n+")"); } 另外还有一个有意思的现象就是当把
SuperClass() { System.out.println("SuperClass()");
}
此句给去掉时子类中(就本程序而言)的SubClss(int n)方法肯定会报错,因为系统在父类中找不到没有参数的构造方法,
如果在该方法的第一句写super(n);(n代表一个整数)就不会错了。
也就是说:如果父类中没有无参数的构造方法,而且子类的构造方法中没有调用父类的其他(有参数的方法,那么就出错了)结合第三条不难理解。