Java接口可以多继承,即一个接口可extends多个父接口;而类只能单继承。当多个父接口有同名同签名default方法时,子接口必须重写该方法,否则编译失败;静态方法不继承,调用需显式指定接口名。

Java接口能“多继承”吗?先说结论
Java类不能多继承,但接口可以多继承——准确说是「多实现」和「多扩展」。接口本身不包含状态,所以interface A extends B, C是合法的;而class X extends Y, Z会编译报错:java: 类 X 从多个类继承。
interface extends 多个父接口时的冲突处理
当多个父接口定义了同名同签名的默认方法(default)或静态方法时,编译器会强制你解决歧义。
- 如果只有抽象方法(无方法体),不冲突,子接口直接继承所有声明
- 如果两个父接口都有
default void foo(),子接口必须重写该方法,否则编译失败 - 若只有一方提供
default实现,另一方只有抽象声明,则子接口自动继承该默认实现 - 静态方法不会被继承,所以不会冲突;调用时必须用
InterfaceName.method()显式指定
interface Flyable {
default void takeOff() { System.out.println("Flying up"); }
}
interface Swimmable {
default void takeOff() { System.out.println("Diving in"); } // 同签名
}
interface Duck extends Flyable, Swimmable {
@Override
default void takeOff() {
Flyable.super.takeOff(); // 必须显式选择一个,或自定义逻辑
}
}
类实现多个接口时 default 方法冲突怎么办
这是更常见的场景:一个类 implements A, B,而 A 和 B 都提供了同名 default 方法。此时编译器同样拒绝含糊其辞。
- 类必须重写该方法,哪怕只是转发给某一方:
A.super.method()或B.super.method() - 不能只写
super.method()—— 编译器不知道你要调谁的 - 如果某个接口的方法被标记为
static,它不会参与默认方法解析,也不可被重写 - 注意:JVM 在运行时不会动态选择 default 实现;选择完全由编译期决定
class Robot implements Flyable, Swimmable {
@Override
public void takeOff() {
System.out.print("Robot chooses: ");
Swimmable.super.takeOff(); // 必须明确指定
}
}
为什么不用 abstract class 替代多接口?关键差异在哪
不是“能不能”,而是“该不该”。接口多继承本质是能力组合(has-a),抽象类继承是本质建模(is-a)。
立即学习“Java免费学习笔记(深入)”;
- 接口无法定义构造器、实例字段、非public方法;抽象类可以
- 一个类只能有一个直接父类,但可实现任意数量接口 → 这是 Java 绕过单继承限制的正统方式
- 从 Java 8 开始,接口支持
default和static方法,但依然禁止实例变量和 final 字段以外的状态 - 如果你发现多个接口总是一起被实现(比如
Serializable & Cloneable & Comparable),考虑是否应提取为一个复合接口,而非强求类去“拼凑”
真正容易被忽略的是:接口继承链过深(如 A extends B, C; B extends D, E; D extends F...)会让方法来源变得隐晦,调试时很难快速定位 default 实现来自哪一层。建议控制接口继承深度 ≤2,并在 Javadoc 中明确标注“此 default 方法源自 X 接口”。










