我正在使用Scala(2.9.1)执行我的第一个有趣的步骤(非hello-world级别),并且我试图理解一个非常无法提供的错误消息。 它很像这样:
error: type mismatch;
found : (Int, Array[InputEntry]) => (Int, Double)
required: (Int, Array[InputEntry]) => ?
entries.groupBy(grouper).map((k: Int, ies: Array[InputEntry]) => (k, doMyStuff(ies)))
正如你可以猜到的,这个片段中的进程应该是进行某些处理的地方,它实际上是一个带有签名Array[InputEntry] => Double
的定义良好的函数。
Grouper的签名是Array[InputEntry] => Int
。
我试图提取一个函数并替换lambda但它没用,而且我一直试图理解错误中的问号......
有什么想法吗?
编辑:我应该澄清一下,InputEntry是我定义的一个类,但是为了这个例子,在我看来它几乎不相关。
答案 0 :(得分:14)
这看起来像问题:
.map((k: Int, ies: Array[InputEntry]) => (k, doMyStuff(ies)))
您需要使用case语句取消应用params并将它们分配给局部变量。您还需要使用{}而不是(),因为它现在是一个匿名函数。
entries.groupBy(grouper).map{case (k, ies) => (k, doMyStuff(ies))}
这是一个更简单的例子。
scala> val x = List(("a",1),("b",2))
x: List[(java.lang.String, Int)] = List((a,1), (b,2))
scala> x.map{ case (str, num) => num }
res5: List[Int] = List(1, 2)
如果您不想使用case语句,则必须将元组保留为单个变量。
scala> x.map(tuple => tuple._2)
res6: List[Int] = List(1, 2)