scala - 在 Scala 中返回其第一个参数的函数的简明实现

标签 scala

在 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/

相关文章:

scala - 在 Scala 中为算术表达式创建 AST

scala - 如何避免 Scala 中类型约束的重复

scala - 可以强制存在量化类型变量只有一个类型吗?

scala - 为什么Scala将Seq转换为List?

scala - 使用惰性参数初始化类时 Scala 编译器的奇怪行为

java - 在 Scala 中处理 BZIP 字符串/文件

Scala 逆变和协变

scala - 查找在 scala 中传递的 lambda 参数的名称

scala - Spark Collect_list 并限制结果列表

Scala 方法来转换点数组