我无法理解以下输出。
我不知道为什么输出为10,我认为该行A a = new B()
创建了B类的新实例,我认为结果应为20
class A {
int i = 10;
}
class B extends A {
int i = 20;
}
public class MainClass {
public static void main(String[] args) {
A a = new B();
System.out.println(a.i);
}
}
为什么这样工作..请解释。
首先,请参见
隐藏字段
(添加了重点)
在一个类中,与超 类中的字段 同名的字段会 隐藏超类的字段 ,即使它们的类型不同
换句话说,这是不是“遗产”,因为你实际上隐藏A
的i
背后B
的i
,和你正在使用的参考对象A
,所以你得到它的领域。如果这样做了B b =new B()
,您将看到20
预期的效果。
如果期望真正的替代,请尝试使用方法。
class A {
public int get() {
return 10;
}
}
class B extends A {
@Override
public int get() {
return 20;
}
}
看到
A a = new B();
System.out.print(a.get()); // 20
如果您真的想一次看到两者,请参见以下示例。
class A {
int i = 10;
}
class B extends A {
int i = 20;
@Override
public String toString() {
return String.format("super: %d; this: %d", super.i, this.i);
}
}
和
A a = new B();
System.out.print(a); // super: 10; this: 20
问题内容: 假设Java具有以下层次结构类: 这是C#中相同代码的(盲)重复: 当我执行Java代码时,我得到了C#返回的信息。 对我来说,C#的结果更有意义,因为引用B调用了它自己的方法。 Java设计者决定打印而不是打印的逻辑是什么?我的意思是,为什么引用B在C中使用覆盖方法?这种方法的优势是什么? 如何更改Java代码以像C#一样打印出来?我的意思是,我怎么教Java调用它使用的完全引用的方
本小节我们将学习 Java 的继承,通过本小节的学习,你将知道什么是继承,继承有什么特点,如何实现继承,方法重写的概念和实现,方法重写和方法重载是比较容易混淆的概念,我们也会介绍两个概念的区别,这些都是本小节的重点,本小节的最后我们还会介绍 super 关键字以及 final 关键字。 1. 概念和特点 1.1 概念 继承是面向对象软件技术当中的一个概念。如果一个类别 B “继承自” 另一个类别
问题内容: 当超类具有标记为final的字段但子类覆盖(隐藏?)此字段时,会发生什么?“最终”并没有阻止它,不是吗?我正在处理的特定示例是Building类,从中继承了各种建筑物。除其他事项外,每种类型的成本对于每个子类都应是最终成本,但是每种类型的建筑物应具有自己的成本。 编辑:从那以后,我意识到我不知道上面我在说什么。我真正想要的是成本的静态变量。但是,如果我在超类中声明这些静态变量,则它们对
问题内容: 问题的简短摘要:我有一个父类,并由子类扩展。 该子类使用super调用Parent的构造函数: 我想知道是否可以在Grandchild类的构造函数中调用super()方法来扩展Child类: 问题答案: super()在继承上一级调用构造函数,如果存在无参数的构造函数,则将隐式调用该构造函数。 对象是从继承的最高层初始化的,在您的情况下是对象>父>子>孙。 从文档中:
问题内容: 我有一个Java类,它会触发自定义Java事件。该代码的结构如下: 一切正常,但是我想创建一个新的A类(称为B),这可能会引发一个新事件。我正在考虑以下修改: 这是正确的方法吗?我在网上搜索示例,但找不到任何示例。 在此解决方案中,有几件事我我不喜欢: 有两种方法,一种使用另一种方法作为参数。 类都具有和方法。是否应该使用private关键字隐藏addAListener? [更新:无法
问题内容: 为什么Java中的枚举不能从其他枚举继承?为什么以这种方式实施? 问题答案: 例子 因为将元素添加到枚举将有效地创建超类,而不是子类。 考虑: 这与常规类的工作方式相反。我想可以以这种方式实施,但实施起来比看起来要复杂得多,而且肯定会使人们感到困惑。