微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在Scala中,使用`_`和使用命名标识符有什么区别?

当我尝试使用_而不是使用命名标识符时,为什么会收到错误

scala> res0
res25: List[Int] = List(1,2,3,4,5)

scala> res0.map(_=>"item "+_.toString)
<console>:6: error: missing parameter type for expanded function ((x$2) => "item
 ".$plus(x$2.toString))
       res0.map(_=>"item "+_.toString)
                           ^

scala> res0.map(i=>"item "+i.toString)
res29: List[java.lang.String] = List(item 1,item 2,item 3,item 4,item 5)

解决方法

用来代替这样的变量名的下划线是特殊的;第N个下划线表示匿名函数的第N个参数.所以以下是等价的:

List(1,3).map(x => x + 1)

List(1,3).map(_ + 1)

但是,如果你这样做:

List(1,3).map(_ => _ + 1)

然后,您将列出一个忽略其单个参数并返回由_ 1定义的函数函数(该具体示例将不会编译,因为编译器无法推断第二个下划线具有什么类型).命名参数将如下所示:

List(1,3).map(x => { y => y + 1 })

简而言之,在函数的参数列表中使用下划线表示“我忽略了这个函数体中的这些参数”.在身体中使用它们意味着“编译器”,请为我生成一个参数列表.“这两个用法并不是很好.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐