1。=> 使用
目前知道的基本和匿名函数定义和函数类型声明有关,以及在case语句中的使用
1、 匿名函数定义, 左边是参数 右边是函数实现体 (x: Int)=>{}
2、函数类型的声明,左边是参数类型,右边是方法返回值类型 (Int)=>(Int)
3、By-name-parameter f(p :=>Int)
与2的区别参考:scala By-name-parameter 和 Function type的区别
4、case 语句中 case x => y
ar increase = (x: Int) => x + 1
类似于转化符号,=>指明这个函数把左边的东西(任何整数x)转变成右边的东西(x + 1)。所以,这是一个把任何整数x映射为x + 1的函数。
2。下划线_使用方法
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。