当子父类有重名成员变量时; x
Fu f =new Zi();
f.x是父类的。我理解成父类引用只能查找到自己引用的那一部分,也就是super.因为父类引用只能调用父类的成员
当有覆盖方法method()时,为什么父类的引用会运行子类的覆盖方法?
老师的解释是把f看成new Zi().method();
这就和成员变量矛盾了, 那么new Zi().x就应该是子类的x了。
麻烦来个大神解释个通俗易懂点的。主要是这个覆盖方法在内存建立和被父类引用调用时的过程不明白。
作者: freehiker 时间: 2013-9-16 19:12
多态情况下,成员变量和静态方法看定义对象时谁引用
Fu f = new Zi();
这种情况下,静态函数和成员变量 如果是 f.x的话看Fu类的
还有一点,调用方法的时候,要看看Fu类有没有,要是没有,编译会失败作者: 酱爆 时间: 2013-9-16 19:14 本帖最后由 酱爆 于 2013-9-16 19:19 编辑
FU f = new Zi() 你这里是new了一个子类对象,f指向了这个子类,不就代表这个子类吗??这是我的理解作者: 王广亚 时间: 2013-9-16 19:30
1、成员函数(非静态):编译时:要查看引用变量所属的类中是否有所调用的成员。
在运行时:要查看对象所属的类中是否有所调用的成员。
终而言之:成员函数在多态调用时,编译看左边,运行看右边
2、 成员变量:只看引用变量所属的类。
3、 在多态中,静态成员函数的特点:
不论编译和运行都参考左边(引用型变量所属的类)