静态方法属于类而非对象,类加载时分配内存,不依赖实例,不可访问this、super及非静态成员;main方法必须为静态以供JVM无实例启动;静态方法不可重写,仅支持编译期隐藏。
静态方法不属于对象,它属于类本身。
静态方法在类加载时就分配内存,不依赖任何对象实例;而实例方法必须通过 new 出来的对象调用。JVM 在调用静态方法时,不会压入 this 引用,所以静态方法体内不能直接访问 this、super,也不能直接调用非静态成员(字段或方法)。
static 修饰的)和其它静态方法this.name 或调用 instanceMethod() 会编译报错:non-static variable/method cannot be referenced from a static context
MyClass obj = new MyClass(); obj.staticMethod();,JVM 也只看方法声明是否为 static,实际调用仍走类级别分派,和 obj 是否为 null 无关main 方法必须是静态的JVM 启动时没有创建任何对象,需要一个无需实例就能执行的入口点。public static void main(String[] args) 正是满足这个前提的约定签名。如果去掉 static,JVM 找不到可直接调用的启动方法,会抛出 NoSuchMethodError(运行时报错),而非编译错误。
MyApp.class 后,直接查找符合签名的 static 方法main 也是全局函数,Java 借鉴了这种“无上下文启动”的思路main 里第一行就 new 了对象,也不能反过来让 main 成为实例方法不能。静态方法是编译期绑定(早期绑定),根据引用类型(而非实际对象类型)决定调用哪个方法,因此它支持的是“隐藏(hiding)”,不是“重写(overriding)”。
class Parent {
static void show() { System.out.println("Parent"); }
}
class
Child extends Parent {
static void show() { System.out.println("Child"); }
}
Parent p = new Child();
p.show(); // 输出 "Parent",不是 "Child"
static 去掉,p.show() 就会输出 "Child"(多态生效)Static method hides another static method)真正容易被忽略的是:静态方法看似“方便”,但过度使用会削弱面向对象的封装性与可测试性——比如它无法被 Mockito 等框架轻松 mock,也难以通过继承或组合替换行为。只要涉及状态、依赖或需要扩展,优先考虑实例方法。