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学习笔记-变长参数的主要内容,如果未能解决你的问题,请参考以下文章