大数据面试-Scala

谈谈scala的闭包、柯里化、高阶函数

如果一个函数,访问到了它的外部(局部)变量的值,那么这个函数和他所处的环境,称为闭包。
闭包在函数式编程中是一个重要的概念,广泛用于高阶函数、柯里化等技术中。

函数柯里化:把一个参数列表的多个参数,变成多个参数列表;
函数柯里化,其实就是将复杂的参数逻辑变得简单化,函数柯里化一定存在闭包。

高阶函数:1)函数可以作为值进行传递
2)函数可以作为参数进行传递
3)函数可以作为函数返回值返回

package com.scala.Function
object test_bibao {
   
   
  def main(args: Array[String]): Unit = {
   
   
    //普通函数
    def makeMultiplier(factor:Int):Int={
   
   
      return factor+1
    }
    println(makeMultiplier(1))

    //闭包函数:如果一个函数,访问到了它的外部(局部)变量的值,那么这个函数和他所处的环境,称为闭包
    def makeMultiplier1(factor: Int): Int=>Int = {
   
   
      // 定义一个闭包函数
      //val multiplier = (x: Int) => x * factor  //匿名函数
      def multiplier(x:Int):
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

文文鑫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值