scala学习笔记-变长参数(5)

变长参数

在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 }

 

转载于:https://www.cnblogs.com/HeQiangJava/p/6706938.html

你可能感兴趣的:(scala,大数据)