[英]Referencing overloaded top-level Kotlin functions reflectively
简而言之,如何对 Kotlin 中的重载顶级函数进行反射性引用/迭代,例如kotlin.io.println
?
鉴于以下情况:
object Bar {
fun foo(x: Int) = Unit
fun foo(x: Byte) = Unit
fun foo(x: Float) = Unit
}
我可以通过执行以下操作迭代foo
的各种重载:
fun main() {
Bar::class.memberFunctions
.filter { kFunction -> kFunction.name == "foo" }
.forEach { kFunction -> println(kFunction) }
}
产生:
fun com.example.Bar.foo(kotlin.Byte): kotlin.Unit
fun com.example.Bar.foo(kotlin.Float): kotlin.Unit
fun com.example.Bar.foo(kotlin.Int): kotlin.Unit
但是,如果foo
的各种重载被定义为顶级(在 class 或 object 定义之外),例如:
fun foo(x: Int) = Unit
fun foo(x: Byte) = Unit
fun foo(x: Float) = Unit
然后似乎没有办法引用它们。
我尝试在我的示例中使用顶级 function(例如main
)来访问合成 class,这很棘手:
::main::class.memberFunctions
.filter { kFunction -> kFunction.name == "foo" }
.forEach { kFunction -> println(kFunction) }
但它呕吐的事实是它是合成的:
Exception in thread "main" java.lang.UnsupportedOperationException: This class is an internal synthetic class generated by the Kotlin compiler, such as an anonymous class for a lambda, a SAM wrapper, a callable reference, etc. It's not a Kotlin class or interface, so the reflection library has no idea what declarations does it have. Please use Java reflection to inspect this class.
如何引用 Kotlin 中的顶级重载函数?
更具体地说,在其他包/模块中定义的顶级重载函数,例如kotlin.io.println
?
根据定义,顶级函数没有声明 class。
::println.javaClass.declaringClass //will return null
所以你没有 class 来使用反射,因此,你不能枚举 package 的顶级成员。(如果你愿意交易你的灵魂,可以做一些魔法)
引用模棱两可的顶级函数的唯一方法是帮助编译器解决歧义,如下所示:
val functionReference: (Int)->Unit = ::foo
然后你可以调用 functionReference()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.