C# 8.0的接口默认实现允许在接口中提供方法体,使已有实现类无需修改即可使用新方法,解决接口演化时的编译兼容问题;新类可继承或重写默认方法,支持多接口组合,但不能访问私有成员、不支持状态保存,与抽象类有本质区别。
C# 8.0 引入的接口默认实现(Default Interface Methods)允许在接口中为方法提供具体实现,让实现类无需强制重写该方法即可直接使用。 这不是“抽象类替代方案”,而是为接口演化提供向后兼容的能力——比如给已有接口添加新方法时,老实现类不会因编译错误而崩溃。
过去给已发布的接口加新方法,所有实现类都必须立刻更新,否则编译失败。这在大型项目或公开 SDK 中极不现实。默认实现解决了这个问题:
在接口中用普通方法语法写实现体,不加 abstract、virtual 或 sealed(这些关键字在接口默认方法中无效):
public interface ILogger
{
void Log(string message) => Console.WriteLine($"[Log] {message}");
string GetPrefix() => "APP";
// 静态方法、属性、字段、构造函数仍不支持
}
实现类可直接调用,也可用 base.InterfaceName.Method() 显式调用默认实现(C# 8+ 支持):
public class ConsoleLogger : ILogger
{
public void Log(string message)
{
base.Logger.Log($"[CONSOLE] {message}"); // 显式调用接口默认实现
}
}
默认方法看似灵活,但有明确边界:
this 上下文指向实例)virtual / override —— 接口方法本身不参与虚方法表继承链默认接口方法 ≠ 抽象类:

this 的完整类型信息(比如不能调用子类特有方法)virtual 方法支持运行时多态分发;接口默认方法是静态绑定到接口定义处的基本上就这些。它不是为了鼓励“把逻辑全塞进接口”,而是为了解决真实世界中接口演进的兼容性难题——用得克制,效果最好。