scala的闭包

闭包在spark中经常会看到,但理解也不难,按照闭包的构造可进行如下定义:

闭包首先有函数嵌套,内部函数引用外部函数的变量,然后返回一个函数

举个栗子:

object SparkDemo01 {

  def main(args: Array[String]): Unit = {

    println(makeAdd()(20))

  }

  def makeAdd() = {
    val more = 10
    (x:Int) => x + more
  }
}

为啥要用函数嵌套?

需要外部函数的作用主要是隐藏变量,限制变量作用的范围。

有些人看到【闭包】这个名字,就一定觉得要用什么包起来才行。其实这只是翻译问题,闭包的原文是Closure,跟【包】没有任何关系

所以函数套函数只是为了造出一个局部变量,跟闭包无关。

为啥要return函数呢?

很明显,不return函数无法使用闭包

可将more变成makeAdd的参数,那么就是下面的形式:

def makeAdd(more : Int) = (x: Int) => x + more

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值