Java继承通过extends实现“is-a”关系,复用父类非私有成员并支持重写与扩展;单继承但可多层传递,需用super()调用父类构造器;private成员不可直接访问,static成员不参与多态;应合理使用protected、final等修饰符控制复用与扩展。

Java 中的继承通过 extends 关键字实现,核心目标是复用已有类的属性和方法,同时支持子类扩展或重写行为。它不是简单复制代码,而是建立“is-a”关系,让子类天然拥有父类的非私有成员(字段、方法),并可在此基础上定制逻辑。
继承的基本语法与结构
子类用 extends 显式声明继承父类,一个类只能直接继承一个父类(单继承),但可多层传递(如 C extends B, B extends A)。父类构造器不会被自动继承,但可通过 super() 在子类构造器首行调用。
- 父类中 private 成员不可被子类直接访问(但可通过 public/protected 方法间接使用)
- static 成员属于类本身,子类可直接通过类名调用,不参与多态
- 子类无法继承父类的构造器,但必须在自己的构造器中显式或隐式调用父类构造器
代码复用的三种典型方式
继承带来的复用不是静态拷贝,而是在运行时动态体现:
- 直接使用:子类对象可直接调用父类的 public/protected 实例方法和字段(如 student.getName() 调用父类 Person 的 getName)
- 方法重写(Override):子类提供同签名方法重新定义行为(需加 @Override 注解),运行时按实际类型调用(动态绑定),支撑多态
- 模板方法模式基础:父类定义算法骨架(含 final 方法 + 可重写钩子方法),子类只定制关键步骤,避免重复控制流程代码
继承中的访问控制与设计约束
是否能复用,取决于父类成员的访问修饰符和设计意图:
立即学习“Java免费学习笔记(深入)”;
- 用 protected 替代 package-private 更利于受控复用(子类可访问,包外不可)
- 父类方法若标记为 final,则禁止子类重写,确保核心逻辑不被破坏
- 父类若声明为 final class,则彻底禁止继承,常见于工具类(如 String、Math)
- 过度继承易导致脆弱基类问题——父类修改可能意外破坏子类行为,此时优先考虑组合(has-a)而非继承(is-a)
一个简洁示例:Animal → Dog 继承链
class Animal {
protected String name;
public Animal(String name) { this.name = name; }
public void move() { System.out.println(name + " is moving"); }
}
class Dog extends Animal {
public Dog(String name) { super(name); }
@Override
public void move() { System.out.println(name + " is running"); }
public void bark() { System.out.println(name + " is barking"); }
}
Dog 复用了 name 字段、构造逻辑和 move() 框架,重写了 move() 行为,并新增 bark() 特有功能——复用与扩展自然融合。
基本上就这些。继承不是为了多写几个 class,而是让共性下沉、差异上浮,让代码更贴近现实关系,也更容易维护和演进。










