以下是我正在尝试做的一个非常简单的说明:
interface Event {
fun value(): Int
}
class Event1: Event {
override fun value() = 1
}
class Event2: Event {
override fun value() = 2
}
interface EventConsumer where T: Event {
fun consume(event: T)
}
class Event1Consumer: EventConsumer {
override fun consume(event: Event1) {
println(event.value())
}
}
class Event2Consumer: EventConsumer {
override fun consume(event: Event2) {
println(event.value())
}
}
class EventManager {
private val consumers: Map, EventConsumer> = mapOf(
Event1::class to Event1Consumer(),
Event2::class to Event2Consumer()
)
fun consume(event: Event) {
val consumer = consumers[event::class]
consumer?.consume(event)
}
}
最后的方法调用(consumer.consume())给了我一个编译器错误
Out-projection类型'EventConsumer ?'禁止使用'public abstract fun consume(event:T):EventConsumer中定义的单位'
我知道Kotlin对泛型的要求比Java要严格得多,这可能就是为什么它不起作用,但是我如何正确地实现这样的东西呢?