Scala 技术笔记之 可变长参数
2024-10-01 07:56:57
转自 http://www.cnblogs.com/rollenholt/p/4112833.html
Scala 允许你指明函数的最后一个参数可以是重复的。这可以允许客户向函数传入可变长度参数列表。想要标注一个重复参数,在参数的类型之后放一个星号。例如:
scala> def echo(args: String*) =
for (arg <- args) println(arg)
echo: (String*)Unit
这样定义, echo 可以被零个至多个 String 参数调用:
scala> echo()
scala> echo("one")
one
scala> echo("hello", "world!")
hello
world!
函数内部,重复参数的类型是声明参数类型的数组。因此, echo 函数里被声明为类型“ String* ”
的 args 的类型实际上是 Array[String]
。然而,如果你有一个合适类型的数组,并尝试把它当作
重复参数传入,你会得到一个编译器错误:
scala> val arr = Array("What's", "up", "doc?")
arr: Array[java.lang.String] = Array(What's, up, doc?)
scala> echo(arr)
<console>:7: error: type mismatch; found : Array[java.lang.String]
required: String
echo(arr)
要实现这个做法,你需要在数组参数后添加一个冒号和一个 _*
符号,像这样:
scala> echo(arr: _*)
What's
up
doc?
这个标注告诉编译器把 arr 的每个元素当作参数,而不是当作单一的参数传给 echo 。因此当形参为String*时,不能直接把类型为Array[String]的实参直接传入,需要通过:_*进行转换。
下划线的用法
转自http://www.zhihu.com/question/21622725
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。
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。
最新文章
- Git-Notes
- HTML5 音频 <;audio>;
- 【bzoj3450】Tyvj1952 Easy
- jquery 获取日期时间
- 【CocoaPods】配置CocoaPods后 - CocoaPods使用
- 终极解决方案:windows10开机黑屏,死机
- 学习笔记_过滤器应用_1(分ip统计网站的访问次数)
- hdu1258Sum It Up (DFS)
- Akka(35): Http:Server side streaming
- 走进Spark生态圈:环境的安装与配置
- 07_SSH免登录配置
- 16_Android生命周期再介绍,通过androidconfigChanges属性让界面旋转时不改变状态中保留的值
- (转)Spring Boot 2 (九):【重磅】Spring Boot 2.1.0 权威发布
- Linux上的压缩与归档
- Hadoop---HDFS读写流程
- Swift语言精要 - 浅谈结构体(Struct)
- leetCode题解之删除单链表中指定的元素
- 移动设备检测类Mobile_Detect.php
- Server 2008作为打印服务器的四大错误解决方案
- jmeter监控内存,CPU等方法
热门文章
- [置顶]
 Java Web学习总结(24)——SSM(Spring+SpringMVC+MyBatis)框架快速整合入门教程
- Spring Cloud-hystrix Dashboard(八)
- 洛谷 P2764 LibreOJ 6002 最小路径覆盖问题
- sync_binlog=1
- 利用Ajax调用controller方法并传递参数
- SPOJ COWPIC(逆序对变形题)
- C 中 main 函数的參数
- [Javascript] 5个最佳的Javascript日期处理类库
- ORA-03137 - ORA-12592 TNS:BAD PACKET OR ORA-3137 故障处理
- vim下的autocmd