Java类继承用extends实现单继承,不支持多重继承;子类仅继承父类非private成员,构造器不继承但必须调用,static成员可继承不可重写,方法重写需遵循签名一致与访问权限不 stricter 规则。

Java 中类继承用 extends 关键字实现,但不能多重继承,且子类只能继承一个父类的非私有成员。
子类声明时必须用 extends 显式指定父类
Java 不支持隐式继承(比如不写 extends 就默认继承 Object 这种语法糖),但所有类最终都隐式继承自 Object —— 仅限于没写 extends 时的兜底行为。一旦你写了 extends,就必须明确写出要继承的类名。
-
class Dog extends Animal✅ 合法 -
class Dog extends Animal, Pet❌ 编译错误:Java 不支持多继承 -
class Dog✅ 合法,等价于class Dog extends Object -
class Dog extends null❌ 编译失败:null不是类名
extends 只能继承 public / protected / 默认包访问权限的成员
子类拿不到父类的 private 字段和方法,哪怕在同一个文件里也不行。常见误判是以为“子类能直接用父类所有非 static 成员”,其实 private 是硬隔离。
- 父类中
private String name→ 子类无法通过this.name或super.name访问 - 想让子类访问,得改成
protected String name或提供public getName()方法 -
static成员可被继承,但不会被重写(只能隐藏);调用时建议用类名而非super
构造方法不会被继承,但子类构造器必须调用父类构造器
子类没有自动继承父类构造方法的机制。每次新建子类实例时,JVM 强制要求第一行执行 super(...)(显式)或默认调用 super()(隐式)。如果父类没有无参构造器,又没显式写 super(...),编译直接报错。
立即学习“Java免费学习笔记(深入)”;
class Animal {
Animal(String name) { this.name = name; }
}
class Dog extends Animal {
Dog(String name) {
super(name); // ✅ 必须写,否则编译失败
}
}
- 若父类只有带参构造器,子类构造器里必须第一行调用
super(…) -
this(...)和super(...)不能共存于同一构造器中 - 构造器链只向上走一层,不支持跳过父类直接调用祖父类构造器
继承后方法重写要注意 @Override 和访问权限规则
子类重写父类方法时,签名必须一致,返回类型需协变(如父类返回 Animal,子类可返回 Dog),且访问权限不能比父类更严格。
- 父类方法是
protected void run(),子类重写不能是private void run()(编译错误) - 推荐始终加
@Override注解:既防拼写错误,也避免意外重载而非重写 - 静态方法不能被重写,只能被隐藏;调用取决于引用类型,不是实际对象类型
最容易忽略的是构造器链的隐式规则和 private 成员的不可见性——这两处出错时往往报错信息不直接指向根源,而是表现为“找不到符号”或“无法访问”。写子类前先确认父类构造器签名、字段访问修饰符,能省掉大半调试时间。










