Java继承中变量访问取决于修饰符、隐藏与引用类型:public/protected/包内默认变量可直接访问,private需getter/setter;super可访问父类变量,this优先子类同名变量;变量不具多态性,访问由编译时引用类型决定。

Java继承中访问变量,关键看变量的访问修饰符和是否被子类同名变量隐藏。父类的public、protected和包内默认(package-private)变量,在子类中可以直接使用;但private变量不能直接访问,只能通过父类提供的public或protected方法间接获取。
直接访问父类非私有变量
如果父类变量是public、protected,或在同一个包中且为默认访问级别,子类对象可直接通过this.变量名或super.变量名访问:
-
this.name:优先访问子类自己定义的同名变量(如果存在) -
super.name:强制访问父类中定义的name变量(即使子类重名) - 若子类未定义同名变量,
this.name和super.name效果相同,都指向父类变量
private变量无法直接访问
父类的private变量对子类完全不可见。子类既不能用this.xxx也不能用super.xxx访问它:
- 编译会报错:“xxx has private access in XXX”
- 正确做法是依赖父类提供的
getter/setter方法,例如super.getName() - 不建议为了访问private变量而修改父类——破坏封装性
变量隐藏(Variable Hiding)要注意
当子类定义了与父类同名的变量(无论类型是否相同),就发生了“变量隐藏”,不是重写(override):
立即学习“Java免费学习笔记(深入)”;
-
this.name→ 访问子类自己的name -
super.name→ 访问父类的name - 静态变量也遵循隐藏规则;但方法是重写,行为完全不同
- 避免同名变量,容易引发逻辑混淆,尤其在多态调用中
多态下变量访问看引用类型
变量访问不具有动态绑定特性,只取决于**编译时的引用类型**:
-
Parent p = new Child(); p.name→ 访问的是Parent类中的name - 哪怕
Child里也有name,只要引用是Parent类型,就看不到子类的 - 方法调用才是看运行时对象类型(动态绑定),变量不是
基本上就这些。核心就三点:修饰符决定可见性、super能绕过隐藏、变量不支持多态。写代码时少用同名变量,多靠方法交互,更安全清晰。











