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.