Scala 神奇的下划线 _
引言
在 Scala 中,下划线 _ 有很多种用法,作为 Scala 初学者也经常被下划线 _ 搞得晕头转向,下面是对 Scala 中下划线 _ 使用的简单总结~
导包时, 下划线 _ 表示引用多个方法,和 java 中的 * 类似
import scala.collection.mutable._
访问元组时,下划线 _ 和值一起使用表示第几个元素
val/var 元组名 = (元素1, 元素2, 元素3....)
//获取第一个元素
元组名._1
//获取第二个元素
元组名._2
_* 表示获取集合一个一个的元素
//:_* 得到集合中的所有元素
val sum = add(1 to 10 :_*)
println(sum)
如果函数参数在函数体中只使用了一次,可以使用下划线 _ 替换
val a = List(1,4,2,7,3,5)
val b = (x:Int,y:Int) => if (x<y)true else false
println(a.sortWith(b))
val c = a.sortWith((x:Int,y:Int) => if (x<y)true else false)
println(c)
println(a.sortWith(_ < _))
使用下划线 _ 来简化函数定义
val a = List(1,2,3,4,5)
//a.foreach(x=>println(x))
a.foreach(println(_))
val a = List(1,2,3,4,5)
//println(a.map(x=>x+1))
println(a.map(_ + 1))
下划线 _ 用于元素匹配,表示集合的每个元素
//元素匹配
List(1,2,3,4,5,6,7,8,9).filter(_ % 2 == 0)
方法隐式转函数: 方法名 _
def m1(x:Int,y:Int):Int = x+y
val f2 = m1 _
类成员变量初始化时,下划线 _ 作为占位符
var gender:String = _
下划线 _ 用于模式匹配中默认匹配项
str match {
case "hadoop" => println("大数据分布式存储和计算框架")
case "zookeeper" => println("大数据分布式协调服务框架")
case "spark" => println("大数据分布式内存计算框架")
case _ => println("未匹配")
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)