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
相关文章推荐
- Scala中的下划线到底有多少种应用场景?
- Scala中的下划线到底有多少种应用场景?
- Scala中的下划线到底有多少种应用场景?
- Scala中的下划线到底有多少种应用场景?
- Scala中的下划线应用场景
- Scala中下划线的应用层场景
- Scala下划线的应用场景
- scala中下划线应用场景
- Scala的实际应用场景
- Scala中Stream的应用场景及其实现原理
- scala akka 修炼之路5(scala特质应用场景分析)
- scala的intersect的一种应用场景
- 人脸识别技术的应用场景,你了解多少?
- Scala中Stream的应用场景及事实上现原理
- scala中_(下划线)使用场景总结
- 盲目出炉的支付场景 到底有多少是鸡肋?
- Scala中Stream的应用场景及其实现原理
- scala akka 修炼之路5(scala特质应用场景分析)
- app多少钱,开发一款app到底多少钱合适,开发一款APP应用大概需要多少钱
- scala中协变(Covariation)的应用场景