答案是不能重写,也就是不能被覆盖!
但是,与实例方法一样,子类能把父类的静态方法继承过来。
父类代码:
public class StaticParent {
public static int a = 0;
public static void printA() {
System.out.println("In Parent, a = " + a);
}
}①子类不重写:
public class StaticSon extends StaticParent {
public static void main(String[] args) {
printA();
}
}
运行结果:

②子类重定义静态方法:
public class StaticSon extends StaticParent {
public static void main(String[] args) {
printA();
}
// @Override
public static void printA() {
System.out.println("In son a = " + a);
}
}运行结果:

③子类覆盖父类的静态方法,这里用到了Java的重写标记(@Override),它表示下面的方法必须重写父类的方法:
public class StaticSon extends StaticParent {
public static void main(String[] args) {
printA();
}
@Override
public static void printA() {
System.out.println("In son a = " + a);
}
}
运行结果:

小结: 静态方法不能被覆盖(情况③)。但是子类可以重新定义父类的静态方法,并将父类的静态方法屏蔽掉(情况②)。
取消屏蔽可以使用 父类名.静态方法名的方式调用,如本例中:
public class StaticSon extends StaticParent {
public static void main(String[] args) {
printA();
}
//@Override
public static void printA() {
System.out.println("In son a = " + a);
StaticParent.printA(); // call
}
}
参考: Java语言程序设计(基础篇) 10版 11章 11.4节 357页
本文探讨了Java中静态方法是否能被子类重写的问题。总结得出结论:静态方法不能被重写,但可以通过子类重新定义来实现类似的效果。文章还介绍了如何通过显式调用父类方法来实现方法的共存。
532

被折叠的 条评论
为什么被折叠?



