scala学习笔记-变长参数

Posted java一生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了scala学习笔记-变长参数相关的知识,希望对你有一定的参考价值。

变长参数

在Scala中,有时我们需要将函数定义为参数个数可变的形式,则此时可以使用变长参数定义函数。

1 def sum(nums: Int*) = {
2   var res = 0
3   for (num <- nums) res += num
4   res
5 }
6 
7 sum(1, 2, 3, 4, 5)

使用序列调用变长参数

在如果想要将一个已有的序列直接调用变长参数函数,是不对的。比如val s = sum(1 to 5)。此时需要使用Scala特殊的语法将参数定义为序列,让Scala解释器能够识别。这种语法非常有用!一定要好好主意,在spark的源码中大量地使用到了。

val s = sum(1 to 5: _*)

1 案例:使用递归函数实现累加
2 
3 def sum2(nums: Int*): Int = {
4   if (nums.length == 0) 0
5   else nums.head + sum2(nums.tail: _*)
6 }

 

以上是关于scala学习笔记-变长参数的主要内容,如果未能解决你的问题,请参考以下文章

Scala-变长参数

Scala系列

scala言语基础学习

Scala函数使用可变参数

Scala可变参数列表,命名参数和参数缺省

Programming In Scala笔记-第二三章