那就是它。是否可以通过Kotlin中的反射调用数据类的copy()函数?我怎样才能引用函数本身?是否有所有数据类的超类? (我无法找到它......)
答案 0 :(得分:9)
所有data
类都没有常见的超类型。
基本上,copy
是一个普通的成员函数,您可以使用Kotlin reflection API调用,如下所示:
val person = Person("Jane", 23)
val copy = person::class.memberFunctions.first { it.name == "copy" }
val instanceParam = copy.instanceParameter!!
val ageParam = copy.parameters.first { it.name == "age" }
val result = copy.callBy(mapOf(instanceParam to person, ageParam to 18))
println(result) // Person(name=Jane, age=18)
确保将kotlin-reflect
添加为依赖项。
上面的示例显示了如何省略默认参数的值 - 没有为name
传递值。如果要传递所有参数,可以通过更简单的方式完成:
val person = Person("Jane", 23)
val copy = person::class.memberFunctions.first { it.name == "copy" }
val result = copy.call(person, person.name, 18)
println(result) // Person(name=Jane, age=18)
如果你传递所有参数的参数,Kotlin反射API并不是调用函数所必需的,你也可以通过Java反射来实现:
val person = Person("Jane", 23)
val copy = person::class.java.methods.first { it.name == "copy" }
val result = copy.invoke(person, person.name, 18)
println(result) // Person(name=Jane, age=18)
答案 1 :(得分:0)
因此,基于上述https://stackoverflow.com/users/2196460/hotkey的答案:
fun <T : Any> clone (obj: T): T {
if (!obj::class.isData) {
println(obj)
throw Error("clone is only supported for data classes")
}
val copy = obj::class.memberFunctions.first { it.name == "copy" }
val instanceParam = copy.instanceParameter!!
return copy.callBy(mapOf(
instanceParam to obj
)) as T
}