Java的细节太多,几天不看就有些晕~~~~
public class A { protected String a = "1"; public String getA(){ return this.a; } }
public class B extends A {
protected String a = "2"; // public String getA(){ // return a; // } public static void main(String[] args) { B x = new B(); System.out.println(x.getA()); } }
输出的是1,父类的方法看到的变量是父类中的a。 如果B中也写一个getA方法,看到的a就是子类中的a了。
所以,不要妄想子类重新声明变量的值就可以一了百了啦。
其实就是可见性的问题。 父类和子类的变量是同时存在的,即使是同名。 子类中看到的是子类的变量,父类中看到的是父类中的变量。 它们互相隐藏,而同名的方法则是实实在在的覆盖。
如A x = new B(); x是一个B,也是一个A, 那么调用方法时,是根据对象的实际类型调用的, 实际类型是B,所以永远调用子类的方法。
而访问成员变量就不同了,它是B时,访问的是子类的成员变量, 转型为A的话,访问的就是父类的成员变量了。
|