我试着学习Scala中的咖喱函数,请参阅代码
def isEven(v: Int): Boolean = v % 2 == 0
def evens(numbers: List[Int])(even: Int => Unit) {
for (number <- numbers; if isEven(number)) {
even(number)
}
}
val my = List.range(1, 100)
evens(my){println(_)} // works fine and prints the even numbers as expected
val recurse = evens(my) { yield _ } //compilation error我希望得到产量积累的结果,但我不能罚款如何在Scala文档或任何示例中这样做。有什么想法吗?
发布于 2014-10-01 20:07:17
不能抽象出for使用的两种形式。一种是foreach,另一种是map和(可能) flatMap;返回类型也不同。
您可以编写两个函数,也可以编写一个泛型方法并忽略返回值:
def evens[A](numbers: List[Int])(even: Int => A): List[A] = {
for (number <- numbers if (number % 2) == 0) yield even(number)
}现在,如果您希望列表保持不变,可以使用identity函数:
val e = evens(my)(identity)
val e = evens(my)(x => x) // Equivalent如果要对其进行处理,则忽略返回值:
evens(my)(println)发布于 2014-10-04 08:25:14
Scala咖喱函数不像我在我的问题中尝试过的那样,可以与收益率一起使用,因此根本没有必要使用咖喱函数,因为您只需这样做:
def evens(numbers: List[Int]) : List[Int] = {
for (number <- numbers if (number % 2) == 0) yield number
}然后:
val my = List.range(1, 100)
evens(my).foreach(f => println(f))感谢@RexKerr的解决方案,他展示了如何利用泛型和咖喱函数生成并返回咖喱结果。
https://stackoverflow.com/questions/26149409
复制相似问题