我想隐式地将函数A => B
转换为List[A] => List[B]
。隐式提升scala
我写了下面隐含的定义:
implicit def lift[A, B](f: A => B): List[A] => List[B] = ...
不幸的是,当我写了下面的代码,含蓄不适用:
val plusOne: (List[Int]) => List[Int] = (x: Int) => (x + 1)
如果我注释有明确时间的功能,工作正常。
为什么?我该如何解决它?
UPDATE。看来这个问题是特定于匿名函数的。比较:
@Test
def localLiftingGenerics {
implicit def anyPairToList[X, Y](x: (X, Y)): List[X] => List[Y] = throw new UnsupportedOperationException
val v: List[String] => List[Int] = ("abc", 239)
}
@Test
def localLiftingFuns {
implicit def fun2ListFun[X, Y](f: X => Y): List[X] => List[Y] = throw new UnsupportedOperationException
val v: List[String] => List[Int] = ((x: String) => x.length)
}
第一个编译得很好。第二个被标记为错误
您可以提供用于实现“隐式def”的代码吗? – 2012-07-11 21:25:23
@ChrisJamesC更新了测试用例 – 2012-07-11 21:28:02
您确定您需要/想要这样做吗? “地图”为少数人物购买了很多清晰的内容,例如'val plusOne:(List [Int])=> List [Int] = _ map(_ + 1)'实际上比您的版本短。 – 2012-07-11 21:53:29