原因在Java语言规范的15.11节中的示例中进行了说明,如下所示:
…
最后一行表明,实际上,所访问的字段不依赖于所引用对象的运行时类。
即使s持有对类对象的引用T,表达式也s.x指向x类的字段S,因为表达式的类型s是S。T类的对象包含两个名为的字段x,一个用于类T,一个用于其超类S。缺少对字段访问的动态查找,使得程序可以通过简单的实现高效地运行。 后期绑定和覆盖的功能是可用的,但是仅当使用实例方法时才可以使用 …
因此,性能是一个原因。字段访问表达式的求值规范如下:
- 如果该字段不是
static:…
* 如果该字段是非空白字段`final`,则结果是`T`在 _Primary_ 值所引用的对象中找到的类型为具名成员字段的值。
在您的情况下, Primary 是指
derived类型为的变量
MyClass。
正如@Clashsoft所建议的,另一个原因是在子类中,字段没有被覆盖,而是被 隐藏了
。因此,允许根据声明的类型或使用强制类型访问哪些字段是有意义的。对于静态方法也是如此。这就是为什么根据声明的类型确定字段的原因。与实例方法重写不同,后者取决于实际类型。上面的JLS引用确实隐式提到了这个原因:
后期绑定和覆盖的功能是可用的,但仅当使用实例方法时才可用。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)