Kotlin Reflection - Returns 一个根据其 属性 名称设置属性值的实例
Kotlin Reflection - Returns an instance with set properties values based on it's property name
我正在尝试创建一个函数,该函数 returns 任何数据 class 对象设置它的 属性 值及其 属性 名称(如果所有字符串)而不更改它是默认值
我有一个例子:
想象一下这个数据class:
data class StudentProfile(
var fullName: String = "",
var mobilePhone: String = "",
var birthDate: String = "",
var email: String = ""
)
我想保留这个空的默认值,但我想要一个适用于任何 class 和 returns(在本例中)的通用函数:
return StudentProfile(
mobilePhone = "mobilePhone",
fullName = "fullName",
email = "email",
birthDate = "birthDate"
)
可能吗?
这听起来像是一个 X-Y 问题(我无法想象它有什么用),但我认为无论如何解决它都会很有趣。
我不清楚你是否要替换默认值(因为你说你不想,但你的例子确实如此),所以这个例子让你选择。
说明:确保构造函数的所有参数都是字符串或可选的(具有默认值)。否则,这是不可能的,因为无法指定非字符串参数值。然后过滤参数列表以仅包含我们设置为它们自己名称的那些,并将它们与它们的名称相关联以创建我们可以传递给 constructor.callBy
.
的 Map<KParameter, String>
fun <T: Any> produceWithPropertiesByOwnName(type: KClass<T>, overrideDefaults: Boolean): T {
val constructor = type.primaryConstructor!!
val parameters = constructor.parameters
if (!parameters.all { param -> param.type.classifier == String::class || param.isOptional }){
error("Class $type primary constructor has required non-String parameters.")
}
val valuesByParameter = parameters.filter { it.type.classifier == String::class && (!it.isOptional || overrideDefaults) }
.associateWith(KParameter::name)
return constructor.callBy(valuesByParameter)
}
我正在尝试创建一个函数,该函数 returns 任何数据 class 对象设置它的 属性 值及其 属性 名称(如果所有字符串)而不更改它是默认值 我有一个例子:
想象一下这个数据class:
data class StudentProfile(
var fullName: String = "",
var mobilePhone: String = "",
var birthDate: String = "",
var email: String = ""
)
我想保留这个空的默认值,但我想要一个适用于任何 class 和 returns(在本例中)的通用函数:
return StudentProfile(
mobilePhone = "mobilePhone",
fullName = "fullName",
email = "email",
birthDate = "birthDate"
)
可能吗?
这听起来像是一个 X-Y 问题(我无法想象它有什么用),但我认为无论如何解决它都会很有趣。
我不清楚你是否要替换默认值(因为你说你不想,但你的例子确实如此),所以这个例子让你选择。
说明:确保构造函数的所有参数都是字符串或可选的(具有默认值)。否则,这是不可能的,因为无法指定非字符串参数值。然后过滤参数列表以仅包含我们设置为它们自己名称的那些,并将它们与它们的名称相关联以创建我们可以传递给 constructor.callBy
.
Map<KParameter, String>
fun <T: Any> produceWithPropertiesByOwnName(type: KClass<T>, overrideDefaults: Boolean): T {
val constructor = type.primaryConstructor!!
val parameters = constructor.parameters
if (!parameters.all { param -> param.type.classifier == String::class || param.isOptional }){
error("Class $type primary constructor has required non-String parameters.")
}
val valuesByParameter = parameters.filter { it.type.classifier == String::class && (!it.isOptional || overrideDefaults) }
.associateWith(KParameter::name)
return constructor.callBy(valuesByParameter)
}