方法重载与下转型要注意的误区
方法重载与上转型要注意的误区
//父类 super class public class Super { String name = "parent"; public String getName() { return name; } } //子类 public class Son extends Super{ String name = "son"; //重新父类中的方法 public String getName() { return name; } } public class Test { // 父类中的成员变量是否能覆盖呢 public static void main(String[] args) { Super su = new Son(); System.out.println(su.getName()); // son System.out.println(su.name); // parent } }
有上面的例子,我们可以看到,子类重写了(覆盖)父类中的方法 getName。我们用一个上转型的对象来分别调用类中的成员变量和方法,我们发现方法中输出的是子类的结果,而成员变量依旧是父类的结果。
以前我们通常认为:上转型对象无论是成员变量,还是成员方法都是优先访问子类的.
但上面的例子的结果似乎不太符合我们一贯的概念,我们思考一些方法重写的概念,子类中重写了父类一个非私有方法,该方法的参数,方法名,返回值均与父类相同,我们说 子类 重写(覆盖)了父类的方法。
但我们忽略了一条:只有动态方法才有override,静态方法,静态域,动态域都是不会被覆盖的。
简单的理解为,只有动态方法才能被覆盖,所以 su.name 压根就没被子类覆盖,所以它的结果应该是 parent.