好程序员大数据教程分享Scala系列之闭包,闭包是一个函数,返回值依赖于声明在函数外部的一个或多个变量。程序员
函数体内能够方法相应做用域内的任何变量。闭包
闭包一般来说能够简单的认为是能够访问一个函数里面局部变量的另一个函数。函数
普通函数:大数据
val multiplier = (i:Int) => i * 10 spa
函数体内有一个变量 i,它做为函数的一个参数。教程
val multiplier = (i:Int) => i * factorip
在 multiplier 中有两个变量:i 和 factor。其中的一个 i 是函数的形式参数,在 multiplier 函数被调用时,i 被赋予一个新的值。然而,factor不是形式参数,而是自由变量,考虑下面代码:作用域
var factor = 3
val multiplier = (i:Int) => i * factor 变量
这里咱们引入一个自由变量 factor,这个变量定义在函数外面。object
这样定义的函数变量 multiplier 成为一个"闭包",由于它引用到函数外面定义的变量,定义这个函数的过程是将这个自由变量捕获而构成一个封闭的函数。
object Test {
def main(args: Array[String]) {
println( "muliplier(1) value = " + multiplier(1) )
println( "muliplier(2) value = " + multiplier(2) )
}
var factor = 3
val multiplier = (i:Int) => i * factor }