我尝试过以下方法:
trait Evidence[H <: HList, T[_]] {}
object Evidence {
implicit def HNilEvidence[T[_]] = new Evidence[HNil, T] {}
implicit def HListEvidence[Head, Remaining <: HList, T[_]](implicit headEv: T[Head], remainingEv: Evidence[Remaining, T]) =
new Evidence[Head :: Remaining, T] {}
}
Run Code Online (Sandbox Code Playgroud)
只有当所有元素都匹配类型类时,这才能正确地给我一个隐含的证据.
但是,当试图像这样使用它时(一个人为的例子):
def transform[A](a: A)(implicit ev: Evidence[A :: HNil, Ordering]) =
{ List(a,a).sorted }
Run Code Online (Sandbox Code Playgroud)
这给出了错误
error: No implicit Ordering defined for A.
Run Code Online (Sandbox Code Playgroud)
哪个应该在那里存在 Evidence[A :: HNil, Ordering]
小智 2
您不需要定义自己的Evidence类型类。使用无形的ops.hlist.LiftAll。
def transform[A](a: A)(implicit
liftAll: LiftAll.Aux[Ordering, A :: HNil, Ordering[A] :: HNil],
isHCons: IsHCons.Aux[Ordering[A] :: HNil, Ordering[A], HNil]): List[A] = {
implicit val ordering: Ordering[A] = liftAll.instances.head
List(a, a).sorted
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
364 次 |
| 最近记录: |