Java接口支持多继承(可extends多个接口),类仅支持单继承但可通过implements多个接口实现能力组合;接口间同名默认方法需重写,类实现多接口时冲突的default方法必须显式覆盖。

Java 接口不支持传统意义上的“多继承”,但允许一个接口 extends 多个接口,这是语法上唯一合法的“多继承”形式;类只能单继承,但可通过实现多个接口达成能力组合——这才是实际开发中真正用得上的多继承替代方案。
接口可以 extends 多个接口,但类不能 extends 多个类
Java 中 interface 支持用逗号分隔的方式同时继承多个父接口,编译器会检查方法签名是否冲突。而 class 的 extends 关键字只接受一个父类,写多个会直接报错 error: class X inherits from multiple classes(实际错误信息为 error: '{' expected 或类似语法错误)。
public interface Readable extends Serializable, Comparable{ void read(); }
-
Serializable和Comparable都是接口,所以可以同时extends - 如果误写成
extends Object, Cloneable,会编译失败——因为Object是类,不能出现在接口的extends列表中 - 若两个父接口定义了同名同签名的默认方法(如都含
default void log() { }),子接口必须重写该方法,否则编译报错
类实现多个接口时,需显式覆盖冲突的默认方法
当一个类 implements 多个接口,且这些接口提供了相同签名的 default 方法时,Java 要求该类必须提供自己的实现,否则编译失败。这不是可选优化,而是强制约束。
interface A { default void run() { System.out.println("A"); } }
interface B { default void run() { System.out.println("B"); } }
class C implements A, B {
@Override
public void run() {
A.super.run(); // 显式调用某一方实现
}
}
- 不写
@Override public void run()会导致编译错误:error: class C inherits unrelated defaults for run() from types A and B - 必须用
A.super.run()或B.super.run()明确指定调用路径,不能只写super.run() - 如果某个接口还定义了
static方法,它不会参与冲突判断,因为静态方法不能被继承覆盖
用接口多继承组织能力契约,避免抽象类滥用
比起层层抽象类继承,用接口组合更能表达“对象具有哪些能力”,例如网络请求模块常拆分为 Cancelable、Retryable、Observable 等小接口,再由具体实现类按需组装。这种设计更轻量、更易测试、也更符合面向接口编程原则。
立即学习“Java免费学习笔记(深入)”;
- 每个接口职责单一,比如
Cancelable只含cancel()和isCanceled() - 实现类可自由组合:
class OkHttpRequest implements Cancelable, Retryable, Observable - 避免为复用代码而强行拉一个抽象基类,导致子类被迫继承无关行为(如让数据库实体继承网络相关方法)
- 注意:接口不能定义构造器或实例字段,所有状态仍需由实现类自己管理
真正容易被忽略的是默认方法的调用链限制——接口的 default 方法无法访问实现类的私有成员或 this 引用的非接口方法,一旦需要共享复杂逻辑,就得退回到模板方法模式或委托类,而不是硬塞进接口里。










