在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 })

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

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...