super是Java中用于在子类中访问父类成员的语法符号,用于调用父类构造器(首行)、被重写的实例方法及被隐藏的字段,但不可用于static上下文、private成员或重复调用构造器。

super 是 Java 中用于在子类中访问父类成员的关键字,它不是对象,也不是引用,而是一个编译器识别的“语法符号”,本质是告诉 JVM:请从当前类的直接父类中查找对应的方法、字段或构造器。
super调用父类构造器(必须是第一行)
子类构造器默认会隐式调用 super(),即父类无参构造器。如果父类没有无参构造器,或你想显式调用特定父类构造器,就必须用 super(...),且必须放在子类构造器的第一行。
- 不写 super() 时,编译器自动补上;写了就不能再写 this(),二者互斥
- 若父类只有带参构造器,子类构造器必须显式调用 super(参数),否则编译失败
- 例如:super("abc", 100) 调用父类含 String 和 int 参数的构造器
super访问父类被重写的实例方法
当子类重写了父类方法,又需要在子类方法中执行父类原始逻辑时,用 super.方法名() 显式调用。
- 只适用于实例方法(非 static),因为 super 指向的是运行时父类部分的对象视图
- 不能在 static 方法中使用 super(静态上下文无 this/super 绑定)
- 常见于模板方法模式或钩子方法中,如重写 toString() 时拼接父类结果:return "Sub: " + super.toString();
super访问父类中被隐藏的字段(需谨慎)
如果子类定义了与父类同名的实例字段(不是重写,是隐藏),可用 super.字段名 明确访问父类版本。
立即学习“Java免费学习笔记(深入)”;
- 注意:字段不存在“重写”,只有“隐藏”;多态对字段无效,访问哪个字段取决于引用类型(编译期决定)
- 一般不推荐字段隐藏,易引发歧义;优先用 getter/setter 封装
- 例如父类有 protected int value = 10;,子类也声明 int value = 20;,则 super.value 取到 10
super不能做什么?几个关键限制
理解 super 的边界,能避免典型错误:
- 不能在 static 方法、static 块、static 字段初始化器中使用 super
- 不能用 super 访问父类 private 成员(编译报错,private 对子类不可见)
- 不能通过 super 调用父类构造器两次(语法禁止,且仅限构造器首行)
- super() 和 this() 不能共存于同一个构造器中
基本上就这些。super 的核心作用就是“向上委托”——在继承链中精准定位父类行为,它不改变对象本身,只是切换当前作用域的解析起点。用对了,代码更清晰;滥用或误解,反而破坏封装和可读性。










