如何实施[x] - > x在scala中使用无形?

时间:2012-12-23 16:27:58

标签: scala shapeless

def unreturn(lx: Sized[List[Int], Nat._1]): Int = lx head

如何使用shapeless获取一个元素列表的头部?这不编译:

No implicit view available from List[Int] =>
scala.collection.GenTraversableLike[v.A,List[Int]].

not enough arguments for method sizedOps:
(implicit evidence$2: List[Int] =>
scala.collection.GenTraversableLike[v.A,List[Int]])shapeless.
SizedOps[v.A,List[Int],shapeless.Nat._1]. Unspecified value parameter evidence$2.

1 个答案:

答案 0 :(得分:5)

您只需要在参数类型中包含类型成员:

def unreturn(lx: Sized[List[Int], Nat._1] { type A = Int }): Int = lx.head

问题是知道没有(安全)方法与任何其他Sized[List[Int], _1]构建A,但编译器仍然需要证据。