首页 >Java >java教程 >为什么Java的静态变量继承会产生意想不到的结果?

为什么Java的静态变量继承会产生意想不到的结果?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-01 19:10:12723浏览

Why Does Java's Static Variable Inheritance Produce Unexpected Results?

Java 类变量覆盖难题

考虑以下 Java 代码片段:

<br>class爸爸{<pre class="brush:php;toolbar:false">protected static String me = "dad";

public void printMe() {
    System.out.println(me);
}

}

class Son 扩展了爸爸 {

protected static String me = "son";

}

public void doIt() {

new Son().printMe();

}

代码似乎在“Dad”和“Son”类中定义了一个名为“me”的类变量。当调用“doIt()”时,人们可能期望代码打印“son”,因为“Son”是“Dad”的子类。然而,事实并非如此。

为什么“doIt()”打印“dad”?

在 Java 中,类变量不能被覆盖。相反,它们是隐藏的。具体来说,当在子类中声明具有现有名称的类变量时,子类会隐藏继承的类变量,从而有效地创建一个与其父类同名但不同的新类变量。

重写与隐藏

重写涉及为子类中的方法提供不同的实现,以重写超类中的方法。相比之下,隐藏涉及在子类中使用相同的变量名,但它隐藏了从超类继承的变量,并在子类本地创建一个新变量。

如何打印“son”?

为了实现打印“son”的所需行为,不能覆盖类变量。相反,可以使用其他继承技术,例如:

  • 在子类中使用不同的变量名称,例如“myName”而不是“me”。
  • 修改继承的类使用反射的变量(不建议一般使用此方法)。
  • 将值作为构造函数参数传递,如示例所示下面:

带有构造函数参数的示例:

<br>公共类 Person {</p>
<pre class="brush:php;toolbar:false">private String name;

public Person(String name) {
    this.name = name;
}

public void printName() {
    System.out.println(name);
}

}

在在这个例子中,类“Person”有一个设置名称的构造函数。这允许创建“Person”的子类并传递名称的特定值。

以上是为什么Java的静态变量继承会产生意想不到的结果?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn