静态方法不能被重写,只能被隐藏。由于静态方法属于类而非实例,其调用在编译时根据引用类型确定,而非运行时对象类型。例如,Parent p = new Child() 调用 p.show() 时,尽管实际对象是Child,但因p的声明类型为Parent,故执行Parent的show方法。这与实例方法的多态不同,实例方法根据实际对象动态绑定。若子类定义同名静态方法,则父类方法被隐藏,而非重写。使用@Override注解修饰此类“重写”将导致编译错误。这一机制符合静态方法不依赖对象状态的设计初衷。

在Java中,静态方法不能被重写。
静态方法属于类,不属于实例
静态方法是通过 static 关键字定义的,它属于类本身,而不是类的某个实例。因此,静态方法在类加载时就确定了调用关系,不会像实例方法那样根据对象的实际类型进行动态绑定。
当子类定义一个与父类同名的静态方法时,这并不是重写(Override),而是隐藏(Hide)了父类的静态方法。
方法调用取决于引用类型
调用哪个静态方法,完全由引用变量的声明类型决定,而不是运行时对象的实际类型。
立即学习“Java免费学习笔记(深入)”;
例如:
class Parent {
public static void show() {
System.out.println("Parent static show");
}
}
class Child extends Parent {
public static void show() {
System.out.println("Child static show");
}
}
public class Test {
public static void main(String[] args) {
Parent p = new Child();
p.show(); // 输出:Parent static show
}
}
虽然 p 指向的是 Child 实例,但因为 p 的类型是 Parent,所以调用的是 Parent 的静态方法。
与实例方法重写的区别
- 实例方法可以被重写,调用时根据实际对象类型执行(多态)。
- 静态方法不能被重写,只能被隐藏,调用时看的是引用类型。
- 使用 @Override 注解去“重写”静态方法会导致编译错误。
基本上就这些。静态方法的设计初衷就是不依赖对象状态,所以不支持重写是符合语言设计逻辑的。










