1.super的使用 一一一子类重写父类的方法
public class A {
private String nameA="父";
public void getName() {
System.out.println("父类:"+nameA);
}
public static void main(String[] args) {
}
}
//========================================
public class B extends A{
private String nameB="子";
@Override
public void getName() {
System.out.println("子类:"+nameB);
super.getName();
}
public static void main(String[] args) {
B b=new B();
b.getName();
}
}
运行结果
结果分析:
在子类B中,重写了父类的getName方法,如果在重写的getName方法中我们去调用父类的相同方法,就必须要通过super关键字显示的指明出来。
如果不明确出来,MyEclipse会因父类子类混乱而报错“如图一”,(在其他博主中有这样提到:*按照子类优先的原则,相当于还是再调用重写的getName()方法,此时就形成了死循环,执行后会报java.lang.StackOverflowError异常。*然而我测试的却直接报错)当我将super改成this时就会出现上面提到的死循环“如图二”。
图一:
图二:
2.super的使用 一一一子类重写父类的变量
public class A {
String nameA="父";
}
public class B extends A{
String nameA="子";
//=======================================
public void getName() {
System.out.println("子类:"+nameA);
System.out.println("父类:"+super.nameA);
}
public static void main(String[] args) {
B b=new B();
b.getName();
}
}
运行结果:
分析:
因为子类B中有一个和父类一样的字段,所有父类字段被隐藏了,为了获得父类的字段我们就必须使用关键字super。
注:通过super是不能访问父类private修饰的变量和方法的,因为这个只属于父类的私有成员。
3.super的使用 一一一子类的构造方法中
在子类中使用super调用超(父)类的构造方法时,super语句必须放在子类的构造方法中,并作为子类构造方法的第一条语句。
总结
1、调用父类被子类重写的方法;
2、调用父类被子类重定义的成员变量;
3、调用父类的构造方法;
注:在子类的构造方法中,如果没有显式使用super关键字调用超(父)类的某个构造方法,系统会默认在子类中执行super()语句,即自动调用无参构造方法。如果此时超(父)类没有提供无参的构造方法,编译器就会报错。因此用super调用超类构造方法时要保证超类中定义了相对应的构造方法。
例:
因为Employee类中没有显式使用super调用超类的构造方法,所以系统自动调用超类的无参构造方法,但是超类无法提供无参构造方法。所以报错。
改正代码:
此时只需要在超(父)类中添加一个无参构造方法即可。