super用于子类中安全精准访问直接父类的字段、方法或构造器,不创建对象、不跨级查找、遵守访问控制,且仅限实例上下文使用。

super 用来明确调用父类成员,不是“找爸爸”,而是“用好继承那部分”
super 的核心作用就一个:在子类中安全、精准地访问**直接父类**的字段、方法或构造器。它不创建新对象,也不跨级查找,只是告诉 JVM:“我现在要操作的是当前对象里从父类继承来的那部分”。比如子类重写了 toString(),但还想复用父类逻辑,就得写 super.toString();否则会递归调用自己,直接栈溢出。
子类构造器里 super() 不是可选项,是初始化刚需
Java 规定:每个子类构造器第一行,**必须**触发父类构造逻辑。没显式写 super(...),编译器自动补 super()(调无参构造)。一旦父类删了无参构造,子类又没显式调 super(参数),就会报错 Constructor not defined。
-
super()和this()互斥,只能选一个,且必须是构造器首行 - 即使父类构造器只做日志打印,也得调——因为它是初始化父类字段的唯一入口
- 错误示范:
this.name = name;写在super(...)前面 → 编译失败
super.字段名 只能读非 private 父类字段,别指望绕过封装
如果父类有 protected String id;,子类定义同名 String id;,那么 super.id 就能拿到父类值;但若父类字段是 private String id;,super.id 直接编译报错——super 不是后门,它遵守 Java 访问控制规则。
- 常见误用:以为
super能访问private字段 → 实际只能通过父类提供的public/protectedgetter - 调试时有用:比如子类覆盖了字段做缓存,但想比对原始父类值,
super.xxx就是唯一干净出口 - 注意字段“隐藏”(hiding)≠ 方法“重写”(overriding):字段没有多态,
super是唯一区分手段
super 只认直接父类,多层继承不能跳着用
假设 A → B → C,在 C 中写 super.xxx(),永远调的是 B 的版本,哪怕 A 才是源头。想用 A 的逻辑?得让 B 在自己方法里用 super 转发一次。
立即学习“Java免费学习笔记(深入)”;
- 没有
super.super.xxx()这种语法,Java 明确禁止跨级委托 - 静态上下文(
static方法、静态块)里不能用super—— 因为它依赖实例继承链 - 和
this不是“兄弟关系”:两者语义完全不同,this指当前完整对象,super指当前对象的父类视图
最容易被忽略的一点:super 不是引用变量,不能赋值、不能传参、不能判空——它只是编译期的访问指令。写 System.out.println(super); 会编译失败,别把它当对象使。








