4

在下面的程序中。方法根据类型动态调用。但是动态调用变量怎么样。为什么不能这样做?

class Super {

    public int field = 0;
    public int getField() {
        return field;
    }
}

class Sub extends Super {

    public int field = 1;

    public int getField() {
        return field;
    }

    public int getSuperField() {
        return super.field;
    }
}

public class FieldAccess {

    public static void main(String[] args) {
        Super sup = new Sub(); 
        System.out.println("sup.field = " + sup.field + ", sup.getField() = " + sup.getField());
        Sub sub = new Sub();
        System.out.println("sub.field = " + sub.field + ", sub.getField() = " + sub.getField() + ", sub.getSuperField() = "+ sub.getSuperField());
    }
}

输出:

sup.field = 0, sup.getField() = 1
sub.field = 1, sub.getField() = 1, sub.getSuperField() = 0

在这里,如果可以动态找到sup.method(),为什么不能动态获取sup.variable呢?

可能吗?如果不是为什么?

当我们有 (superclas)animal--->Dog,Cat,lion 我们调用它的方法说 makeNoise() 我们分别收到 bark 或 meow...。但是我们为什么不问它的名字并相应地得到它呢?

4

2 回答 2

2

在 Java 中,成员变量具有静态绑定,因为 Java 不允许成员变量的多态行为。

private方法,因为它们永远不会被继承,并且编译器只能在编译时解析对任何私有方法的调用。因此静态绑定。

其次,考虑下面的代码..

class SuperClass{
...
public String someVariable = "SuperClass";
...
}

class SubClass extends SuperClass{
...
public String someVariable = "SubClass";
...
}
...
...

SuperClass superClass1 = new SuperClass();
SuperClass superClass2 = new SubClass();

System.out.println(superClass1.someVariable);
System.out.println(superClass2.someVariable);
...

输出:- 超类超类

成员变量仅基于对象引用的声明类型进行解析,编译器仅在编译时就能够找到该类型,因此在这种情况下为静态绑定。

总而言之,基本上 Java 开发人员不希望这些检查在运行时发生并在此时出现异常。

于 2013-06-25T17:27:29.510 回答
1

当您覆盖超类方法时。

public int getField() {
        return field;
}
于 2013-06-25T17:41:27.380 回答