1

使用给定的 kotlin 代码:

sealed class Event(val id:String= UUID.randomUUID().toString(), val timestamp:Instant = Instant.now())
data class BarEvent(val additionalInfo:String):Event()
object FooEvent:Event()
// data class CorrectFooEvent():Event() // invalid kotlin

fun main(args: Array<String>) {
    val b1 = BarEvent("b1")
    val f1 = FooEvent
    Thread.sleep(1000)
    val b2 = BarEvent("b2")
    val f2 = FooEvent

    println("${b1.id} ${b1.timestamp} $b1")
    println("${f1.id} ${f1.timestamp} $f1")
    println("${b2.id} ${b2.timestamp} $b2")
    println("${f2.id} ${f2.timestamp} $f2")
}

没有问题BarEvent

但是由于FooEvent没有比 中的参数更多的参数Event,我希望它有空的构造函数。它没有被授权用于数据类,所以我把它变成了一个对象。但是对象是单例的,因此它不会表现为实例化事件。

我看到的唯一解决方法(将类保持为 a data class)是这样的:

sealed class Event(open val id:String= UUID.randomUUID().toString(), open val timestamp:Instant = Instant.now())
data class FooEvent(override val id:String= UUID.randomUUID().toString(), override val timestamp:Instant = Instant.now()):Event()

但它不是很优雅。

4

1 回答 1

3

只需更改FooEvent为普通类,然后添加(或使用您的 IDE 生成它们),toString()如果需要:hashCode()equals(Object)

class FooEvent: Event() {
    override hashCode() = ...
    override equals(other: Object) {
        ...
    }
    override toString() = ...
}

要使事件成为数据类,只需向其添加一个未使用的属性。不漂亮,但目前在 Kotlin 中尽可能短:

data class FooEvent(val dummy: Unit = Unit) : Event()

似乎无意很快消除此限制:

于 2017-12-14T07:47:36.740 回答