package hack;
import click. CodeTalk;
public class TypeIt {
private static class ClickIt extends CodeTalk {
void printMessage() {
System.out.println("Hack");
}
}
public static void main(String[ ] args) {
ClickIt clickit = new ClickIt();
clickit.doIt();
}
}
package click;
public class CodeTalk {
public void doIt() {
printMessage();
}
void printMessage() {
System.out.println("Click");
}
}本谜题看起来很直观。 Hack.TypeIt 的 main 方法对 TypeIt. ClickIt 类实例化,
然后调用其 doIt 方法,该方法是从 CodeTalk 继承而来。 接着,该方法调用
printMessage 方法,它在 TypeIt. ClickIt 中被声明为打印 Hack。然而,如果你
运行该程序,它打印的将是 Click。 怎么会这样呢?
上面的分析做出了一个不正确的假设,即 Hack.TypeIt. ClickIt.printMessage
方法覆写了 click. CodeTalk.printMessage 方法。一个包内私有的方法不能被位
于另一个包中的某个方法直接覆写[JLS 8. 4. 8] 。在程序中的这两个 twoMessage
方法是无关的,它们仅仅是具有相同的名字而已。当程序在
import click. CodeTalk;
public class TypeIt {
private static class ClickIt extends CodeTalk {
void printMessage() {
System.out.println("Hack");
}
}
public static void main(String[ ] args) {
ClickIt clickit = new ClickIt();
clickit.doIt();
}
}
package click;
public class CodeTalk {
public void doIt() {
printMessage();
}
void printMessage() {
System.out.println("Click");
}
}本谜题看起来很直观。 Hack.TypeIt 的 main 方法对 TypeIt. ClickIt 类实例化,
然后调用其 doIt 方法,该方法是从 CodeTalk 继承而来。 接着,该方法调用
printMessage 方法,它在 TypeIt. ClickIt 中被声明为打印 Hack。然而,如果你
运行该程序,它打印的将是 Click。 怎么会这样呢?
上面的分析做出了一个不正确的假设,即 Hack.TypeIt. ClickIt.printMessage
方法覆写了 click. CodeTalk.printMessage 方法。一个包内私有的方法不能被位
于另一个包中的某个方法直接覆写[JLS 8. 4. 8] 。在程序中的这两个 twoMessage
方法是无关的,它们仅仅是具有相同的名字而已。当程序在