Scala编程语言中的下划线
2015-01-07 21:15
246 查看
本文转自知乎: Scala中的下划线到底有多少应用场景? 感谢原文作者。
文中总结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。
文中总结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。
相关文章推荐
- Scala语言:集成面向对象和函数式编程的特性
- Spark1.0.0 多语言编程之Scala实现
- 面向对象的函数式编程语言Scala - 简介安装
- scala语言编程spark单词计数
- Spark1.0.0 多语言编程之Scala实现
- Java\Scala\Python三种语言求解经典编程实例(二)—— 尾数前移
- Java\Scala\Python三种语言求解经典编程实例(一)——求水仙花数
- Scala:函数式编程之下划线underscore
- Spark1.0.0 多语言编程之Scala实现
- 初解,Scala语言中基于Actor的并发编程的机制,并展示了在Spark中基于Scala语言的Actor而产生的消息驱动框架Akka的使用,
- Java\Scala\Python三种语言求解经典编程实例(四)—— 求10000以内的自守数
- Spark1.0.0 多语言编程之Scala实现
- Scala:函数式编程之下划线underscore
- Scala:未受重视却潜力巨大的Android编程语言
- Scala语言:集成面向对象和函数式编程的特性
- 漫谈并发编程:Future模型(Java、Clojure、Scala多语言角度分析)
- Scala:函数式编程之下划线underscore
- Java\Scala\Python三种语言求解经典编程实例(三)—— 不重复的3位数
- C++程序设计语言编程风格演变史(转载)
- Linux操作系统下C语言编程入门