我正在尝试将函数read
和write
在我的库中分别转换为运算符函数get
和set
。我的函数使用具体的泛型类型,它们也是内联方法。(你可以在这里看到我的图书馆。)
编译器让我通过没有问题,我不明白为什么使用非运算符函数推理工作得很好,但在运行时使用运算符会失败。
Exception in thread "main" java.lang.UnsupportedOperationException: This function has a reified type parameter and thus can only be inlined at compilation time, not called directly.
at kotlin.jvm.internal.Intrinsics.throwUndefinedForReified(Intrinsics.java:173)
at kotlin.jvm.internal.Intrinsics.throwUndefinedForReified(Intrinsics.java:167)
at kotlin.jvm.internal.Intrinsics.reifyJavaClass(Intrinsics.java:201)
代码如下:
operator inline fun <reified T> get(address: Long): T {
...
}
operator inline fun <reified T> get(address: Int): T = get(address.toLong())
operator inline fun <reified T> set(address: Long, data: T) {
...
}
operator inline fun <reified T> set(address: Int, data: T): Unit = set(address.toLong(), data)
有趣的是,我可以使用中缀函数很好地做到这一点,例如:
class Example { infix inline fun <reified T> foo(bar: Int) = Any() as T }
fun main(args: Array<String>) {
val example = Example()
val foobar: Any = example foo 12345
}
我也可以与其他运算符一起执行此操作,例如这两个工作:
operator inline fun <reified T> minus(bar: Int) = foo<T>(bar)
operator inline fun <reified T> plus(bar: Int) = foo<T>(bar)
我还注意到它甚至invoke
可以正常工作!这很奇怪,因为它似乎两者invoke
都get
具有相同的实现。
operator inline fun <reified T> invoke(bar: Int) = foo<T>(bar)
但是,如果我将以下函数添加到 example:operator inline fun <reified T> get(bar: Int) = foo<T>(bar)
然后尝试以下调用,我会遇到错误:val get: Any = example[12345]