在 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)
给出了预期的结果,但这似乎不必要地冗长。
最佳答案
那是因为
"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
.
关于scala - 在 Scala 中返回其第一个参数的函数的简明实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19627187/