Java多态中成员访问规则为:实例方法动态绑定(运行时看实际对象类型)、成员变量和静态成员静态绑定(编译时看引用类型);仅重写的实例方法体现多态。

在Java多态中,成员的访问遵循不同的规则,具体取决于访问的是成员方法、成员变量还是静态成员。理解这些规则对掌握多态行为至关重要。
成员方法:动态绑定(运行时决定)
当通过父类引用调用一个被子类重写的方法时,JVM会在运行时根据实际对象类型来决定调用哪个版本的方法。这称为动态方法分派。
说明:
- 编译时看左边(引用类型),运行时看右边(实际对象类型)
- 只有实例方法支持重写,才有多态效果
class Animal {
void speak() {
System.out.println("Animal speaks");
}
}
class Dog extends Animal {
@Override
void speak() {
System.out.println("Dog barks");
}
}
public class Test {
public static void main(String[] args) {
Animal a = new Dog();
a.speak(); // 输出 "Dog barks"
}
}
成员变量:静态绑定(编译时决定)
成员变量(字段)不具有多态性。访问哪个变量由引用类型(声明类型)决定,而不是实际对象类型。
立即学习“Java免费学习笔记(深入)”;
说明:
- 即使子类定义了同名字段,通过父类引用访问的仍是父类的字段
- 字段访问在编译阶段就已确定
class Animal {
String name = "Animal";
}
class Dog extends Animal {
String name = "Dog";
}
public class Test {
public static void main(String[] args) {
Animal a = new Dog();
System.out.println(a.name); // 输出 "Animal"
}
}
静态方法和静态变量:与实例无关
静态成员属于类本身,不参与多态。它们的访问完全由引用类型决定。
说明:
- 即使子类重定义了静态方法,调用仍基于引用类型
- 不推荐通过对象调用静态成员,应使用类名直接访问
class Animal {
static void show() {
System.out.println("Animal show");
}
}
class Dog extends Animal {
static void show() {
System.out.println("Dog show");
}
}
public class Test {
public static void main(String[] args) {
Animal a = new Dog();
a.show(); // 输出 "Animal show"(静态方法不重写)
}
}
基本上就这些。记住:方法看对象,变量看引用,静态靠类名。多态主要体现在重写的实例方法上,其他成员访问都不具备运行时多态特性。











