我试图实现一个类似于:
def myMap[A,B](a: Seq[A], f: A => B): Seq[B] = a.map(f)
// then I want to call it like that:
myMap(List(1,13,42), _*2)但是对myMap的调用不编译,因为编译器不能推断类型参数A和B。错误:missing parameter type
基本上,我希望它能推断出A (Int)给定的论点List(1,13,42),然后从给定的f = _*2知情A推断B。但事实并非如此。
我能做什么来避免写类型参数呢?
我发现的最好的是:
def myMap[A,B](a: Seq[A], f: A => B): Seq[B] = a.map(f)
myMap(List(1,13,42), (a: Int) => a*2)也就是说,我在A参数中显式地给出了f
发布于 2016-12-13 11:27:38
使用多参数列表。
def myMap[A,B](a: Seq[A])(f: A => B): Seq[B] = a.map(f)
// then call it like this:
myMap(List(1,13,42)) (_*2)对于foldLeft和类似的函数,集合api大量使用了这种风格。您可以查看正式风格指南这里。。
发布于 2016-12-13 11:14:22
我找到了一种方法,使用隐式类:
implicit class MyMap[A](a: A) {
def myMap[B](f: A => B): B = f(a)
}
// then I can call
List(1,13,42).myMap(_*2)https://stackoverflow.com/questions/41119496
复制相似问题