Kotlin有委托属性这个非常好的功能。但有时候`get()`和`set()`方法并不足够。比如我想懒加载创建一个`Closeable`对象,并稍后关闭它。以下是实现这样的委托属性的示例:
fun <T : Closeable> closeableLazy(initializer: () -> T) =
CloseableLazyVal(initializer)
class CloseableLazyVal<T : Closeable>(
private val initializer: () -> T
) : ReadOnlyProperty<Any?, T> {
private var value: T? = null
override fun get(thisRef: Any?, desc: PropertyMetadata): T {
if (value == null) {
value = initializer()
}
return value
}
fun close() {
value?.close()
}
}
这是我想要使用它的方式:
private val stream by closeableLazy { FileOutputStream("/path/to/file") }
fun writeBytes(bytes: ByteArray) {
stream.write(bytes)
}
override fun close() {
stream::delegate.close() // This line will not compile
}
不幸的是,这种方法不起作用,因为似乎 Kotlin 不允许直接访问属性委托。有没有什么办法可以做到我想要的?或者是否有计划添加这样的功能到 Kotlin 中,因为它将是一个非常好的特性。