您的位置:首页 > 其它

Scala中的下划线到底有多少种应用场景?

2017-04-07 20:12 465 查看

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。

作者:黄辉煌

链接:https://www.zhihu.com/question/21622725/answer/21588672

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

3
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: