当子类和父类拥有相同的方法时
//父类
public class AbstractClass {
public void methodIn(){
System.out.println("AbstractMethodIn");
}
}
//子类
public class RealClass extends AbstractClass{
public void methodOut(){
this.methodIn();
System.out.println("RealMethodOut");
}
public void methodIn(){
System.out.println("RealMethodIn");
}
}
子类和父类拥有相同的方法必然会执行子类中的方法,无论方法是否static修饰的
当子类和父类的方法都为static修饰时
//父类
public class AbstractClass {
public static void methodOut(){
methodIn();
System.out.println("AbstractMethodOut");
}
public static void methodIn(){
System.out.println("AbstractMethodIn");
}
}
//子类
public class RealClass extends AbstractClass{
public static void methodIn(){
System.out.println("RealMethodIn");
}
public static void main(String[] args) {
RealClass realClass = new RealClass();
realClass.methodOut();
}
}
输出结果
AbstractMethodIn
AbstractMethodOut
当子类和父类的方法都无static修饰时
//父类
public class AbstractClass {
public void methodOut(){
methodIn();
System.out.println("AbstractMethodOut");
}
public void methodIn(){
System.out.println("AbstractMethodIn");
}
}
//子类
public class RealClass extends AbstractClass{
public void methodIn(){
System.out.println("RealMethodIn");
}
public static void main(String[] args) {
RealClass realClass = new RealClass();
realClass.methodOut();
}
}
输出结果
RealMethodIn
AbstractMethodOut
总结
造成子类和父类继承下多态的问题主要是JDK编译时的动态链接:
1.编译的时候如果子类继承父类,会将父类的所有属性和方法在子类中拷贝一份,而如果子类重写了相关的方法和属性,则会将已有的属性和方法覆盖。因此一般子类在执行相关方法时会优先执行子类中重写的方法。
2.然而当方法都为static修饰时,如果子类中无对应的实现,则会调用父类的方法,父类的该方法中所有的调用都是调用自身中的方法,因为static的修饰下不会进行动态链接,该方法的所有引用都指向自身。
3.当子类无方法时会优先调用父类方法,而父类方法执行时遇到父类和子类都有的方法会优先执行子类中的方法,这就是动态链接了。
可以试一下第三种情况下都使用this指针调用,结果还是和第三种方法相同。