class="java" name="code">public class Father {
	int x = 10;
	 
    public Father() {
        add(20);
    }
 
    public void add(int y) {
        System.out.println("Father");
        x += y;
    }
}
public class Child extends Father {
	int x = 9;
	 
    public void add(int y) {
        System.out.println("Child");
        System.out.println("X:"+x);
        x += y;
        System.out.println(x + ":  :" + y);
    }
}
public class Test {
	public static void main(String[] args) {
        Father f = new Child();
        System.out.println(f.x);
 
    }
}
?
打印结果为:
Child
X:0
20:? :20
10
?
分析:
1. 父类对象的引用变量 f 引用了子类的实例对象,因此继承了父类的子类实例化时,执行了父类的构造方法,执行了add(20);
?
2. 执行add(20)方法,由于重写覆盖的原因,执行的是子类的add()方法。
?
3. 在Child类中的方法域中,子类的方法调用通过父类的变量引用,变量指针指向的是子类的内存空间,而此时子类方法中的x是通过父类的变量调用的,引用没有开辟内存,没有实例化,所以x=0。
?
4. 通过x = 0; x+=y; 打印出20:20。
?
5. 最后f.x 调用父类 x 变量,打印10.