我正在编写用于处理案例类实例列表的通用代码,
收集每个字段中的值,组合然后将其传递给库。
使用无形LabelledGeneric
和多态函数,它看起来像这样:
object toNamedSingletonListOfValues extends Poly1 {
implicit def caseField[K,T] =
at[FieldType[K, T]](field => { field.key -> List[T](field) })
}
val generic = LabelledGeneric[MyClass]
val records = listOfMyClassInstances.map(generic.to)
val values = records.map(_.map(toNamedSingletonListOfValues)) // Then combining and passing
但是,我需要一种获取
field.key
的方法因为库需要参数名称。你介意提出解决方案吗?
最佳答案
您可以通过 Witness
的实例将键(在编译时已知)作为运行时值进行访问。类型类:
object toNamedSingletonListOfValues extends Poly1 {
implicit def caseField[K, T](implicit wk: Witness.Aux[K]) =
at[FieldType[K, T]](field => { wk.value -> List[T](field) })
}
不需要运行时反射!
关于scala - 如何在运行时枚举无形的记录和访问字段键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24647864/