在Scala中,当我调用"helloworld".groupBy(_.toLower)
时,我得到了预期的结果:
scala> "helloworld".groupBy(_.toLower)
res10: scala.collection.immutable.Map[Char,String] = Map(e -> e, l -> lll, h -> h, r -> r, w -> w, o -> oo, d -> d)
但是当我使groupBy区分大小写(即"helloworld".groupBy(_)
)时,我收到以下错误:
scala> "helloworld".groupBy(_)
<console>:8: error: missing parameter type for expanded function ((x$1) => "helloworld".groupBy(x$1))
"helloworld".groupBy(_)
^
为什么第二个例子不起作用?写"helloworld".groupBy(x => x)
给出了预期的结果,但这似乎不必要地冗长。
答案 0 :(得分:7)
那是因为
"helloworld".groupBy(_)
实际上相当于
x => "helloworld".groupBy(x)
因此,通过使用前一种语法,您实际上定义了一个函数,而不是分组。要查看此内容,请检查
的输出scala> "helloworld".groupBy(_)
<console>:8: error: missing parameter type for expanded function ((x$1) => "helloworld".groupBy(x$1))
"helloworld".groupBy(_)
除此之外,您可以随时使用x => x
而不是identity
。