scala中下划线的几种用法

1. 作为“通配符”,类似Java中的*。如

   import scala.math._

2.:_* 作为一个整体,告诉编译器你希望将某个参数当作参数序列处理!例如 val s = sum(1 to 5:_*) 就是将1 to 5当作参数序列处理。


3、指代一个集合中的每个元素。例如我们要在一个Array a中筛出偶数,并乘以2,可以用以下办法:
      a.filter(_%2==0).map(2*_)
      又如要对缓冲数组ArrayBuffer b排序,可以这样:
      val bSorted = b.sorted(_


4、在元组中,可以用方法_1, _2, _3访问组员。如a._2。其中句点可以用空格替代。

5、使用模式匹配可以用来获取元组的组员,例如
     val (first, second, third) = t
     但如果不是所有的部件都需要,那么可以在不需要的部件位置上使用_。比如上一例中val (first, second, _) = t

6、还有一点,下划线_代表的是某一类型的默认值.

      对于Int来说,它是0。
      对于Double来说,它是0.0
      对于引用类型,它是null。

7.存在性类型:

def foo(l: List[Option[_]]) = ...
8.高阶类型的参数:
case class A[K[_],T](a: K[T])
9.临时变量:val  _ =5

10.临时参数:

List(1, 2, 3) foreach { _ => println("Hi") }
11.  通配模式
Some(5) match { case Some(_) => println("Yes") }
match {
     case List(1,_,_) => " a list with three element and the first element is 1"
     case List(_*)  => " a list with zero or more elements "
     case Map[_,_] => " matches a map with any key type and any value type "
     case _ =>
 }
val (a, _) = (1, 2)
for (_ <- 1 to 10)

12.占位符的用法

val nums = List(1,2,3,4,5,6,7,8,9,10)
 
nums map (_ + 2)
nums sortWith(_>_)
nums filter (_ % 2 == 0)
nums reduceLeft(_+_)
nums reduce (_ + _)
nums reduceLeft(_ max _)
nums.exists(_ > 5)
nums.takeWhile(_ < 8)
13.作为参数名
//访问map
var m3 = Map((1,100), (2,200))
for(e<-m3) println(e._1 + ": " + e._2)
m3 filter (e=>e._1>1)
m3 filterKeys (_>1)
m3.map(e=>(e._1*10, e._2))
m3 map (e=>e._2)
 
//访问元组:tuple getters
(1,2)._2







  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值