Java接口默认方法是Java 8引入的用default关键字定义的非抽象方法,可在不修改已有实现类的前提下为接口新增功能,如List的sort()方法;它必须加default修饰,仅支持public或包访问,不可被final修饰,不能访问实现类实例字段。

Java接口默认方法是什么
默认方法是 Java 8 引入的接口增强机制,允许在 interface 中用 default 关键字定义有具体实现的方法。它不是抽象的,子类或实现类可直接调用,也可选择重写。
核心作用是:在不破坏已有实现类的前提下,为接口新增功能。比如 List 接口在 Java 8 加入 sort() 默认方法,所有已存在的 ArrayList、LinkedList 等无需修改就能用。
为什么必须加 default 关键字
不加 default 的方法在接口里仍是抽象的(即使写了方法体),编译会报错:Modifier 'public' not allowed here 或 Interface method cannot have body。
default 是语法强制标识,告诉编译器:“这是可选实现,不是抽象契约”。它和 static 方法一样,属于接口自身的成员,不参与实现类的继承链。
立即学习“Java免费学习笔记(深入)”;
- 不能用
private、protected修饰默认方法(仅支持public或默认包访问) - 不能被
final修饰(否则实现类无法重写) - 不能访问实现类的实例字段(没有
this指向实现类对象)
默认方法与抽象方法、静态方法的区别
三者共存于接口中,但语义和使用方式不同:
-
default方法:实例方法,通过实现类对象调用,可被重写 -
static方法:属于接口本身,用InterfaceName.method()调用,不可被重写 - 无修饰符的抽象方法:必须由实现类提供具体实现
例如:
interface Logger {
void log(String msg); // 抽象方法
default void info(String msg) {
System.out.println("[INFO] " + msg);
}
static void error(String msg) {
System.out.println("[ERROR] " + msg);
}
}
调用时:logger.info("hello")(对象调用),Logger.error("oops")(接口名调用)。
多重继承冲突时怎么解决
当一个类实现多个接口,且它们都有同签名的 default 方法,编译器会报错:class inherits unrelated defaults for method。
必须在实现类中显式重写该方法,哪怕只是调用其中一个父接口的实现:
class MyLogger implements Logger, VerboseLogger {
@Override
public void info(String msg) {
Logger.super.info(msg); // 明确指定调用哪个接口的 default 实现
}
}
容易忽略的一点:如果某个接口的 default 方法调用了另一个 default 方法,而后者又被重写,那实际执行的是重写后的版本——因为 super 调用只限定在当前接口层级,不穿透到实现类。










