有可能从circe而不是JSON中获取底层hlist表示吗?本质上将case类转换为HList
注意:我知道这可以直接用无形实现,我想尝试基于circe's宏的解析器,因为我遇到了非形状的性能问题。
发布于 2017-10-26 20:29:22
为什么你认为circe中存在“潜在的hlist表示”?
circe所做的是在JSON中引入解析 a String,引入类型类解码器和编码器
trait Encoder[A] extends Serializable { self =>
def apply(a: A): Json
//...
}
trait Decoder[A] extends Serializable { self =>
def apply(c: HCursor): Decoder.Result[A]
//...
}并使用推演对这些类型的类进行shapeless。例如,这意味着如果我们有Decoder[H]和Decoder[T],那么我们就有Decoder[H :: T]。但是,除了circe以外,没有其他案例类的底层杰森表示。
circe不将case类转换为HList,而是shapeless转换。
https://stackoverflow.com/questions/46960370
复制相似问题