scala - 如何在运行时枚举无形的记录和访问字段键?

标签 scala record shapeless

我正在编写用于处理案例类实例列表的通用代码,
收集每个字段中的值,组合然后将其传递给库。

使用无形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/

相关文章:

另一个 Option 对象内的 Scala Option 对象

java - 面向程序员的 Java 5 或 6 或 Scala 中的数据结构和算法书籍,而不是 CS 类(class)教科书

Java录制/混合两个音频流

clojure - 在 Clojure 中,如何仅通过记录的一个实例来获取记录的基础?

android - 状态改变时如何关闭MediaRecorder播放的声音

scala - 使用多态函数从选项中提取对象

scala - 我如何开始学习 scala 中的无形概念

scala - lazyMap其实不懒惰?

scala - 使用 Rapture Http 获取请求

scala - 使用 Shapeless 递归列出空字段