委托 委托模式已被证明是实现继承的一个很好的替代方案,并且 Kotlin 本身就支持它,需要零样板代码。Derived类可以通过将其所有公共成员委托给指定对象来实现Base接口: window.addMouseListener(object : MouseAdapter() { override fun mouseClicked(e: MouseEvent) { /*...*/ } override fun mouseEntered(e: MouseEvent) { /*...*/ } }) Derived超类型列表中的by-子句,表示b将存储在Derived对象的内部,编译器将生成的Base中的所有方法都转发到b。 覆盖委托实现的接口成员 覆盖按您的预期工作:编译器将使用您的override实现而不是委托对象中的实现。如果要添加override fun printMessage() { print("abc") }到Derived,程序将在调用printMessage时打印 abc 而不是 10 : interface Base { fun printMessage() fun printMessageLine() } class BaseImpl(val x: Int) : Base { override fun printMessage() { print(x) } override fun printMessageLine() { println(x) } } class Derived(b: Base) : Base by b { override fun printMessage() { print("abc") } } fun main() { val b = BaseImpl(10) Derived(b).printMessage() Derived(b).printMessageLine() } 但是请注意,以这种方式覆盖的成员不会从委托对象的成员中调用,委托对象只能访问其自己的接口成员实现: interface Base { val message: String fun print() } class BaseImpl(val x: Int) : Base { override val message = "BaseImpl: x = $x" override fun print() { println(message) } } class Derived(b: Base) : Base by b { // This property is not accessed from b"s implementation of `print` override val message = "Message of Derived" } fun main() { val b = BaseImpl(10) val derived = Derived(b) derived.print() println(derived.message) } 输出: BaseImpl: x = 10 Message of Derived