Scala学习-函数柯里化、闭包、递归

闭包

函数式编程的标配

如果一个函数,访问到了它的外部(局部)变量的值,那么这个函数和他所处的环境,称为闭包

object Test{
    def main(args: Array[String]): Unit = {
        def add(a: Int, b: Int): Int = {
            a + b
        }

        //1.固定一个考虑加数场景
        def addByFour(b: Int): Int = {
            4 + b
        }

        //2.扩展固定加数改变的情况
        def addByFive(b: Int): Int = {
            5 + b
        }

        //3.将固定加数作为另一个参数传入,但是作为“第一层参数“传入””-
        def addByA(a: Int): Int => Int = a + _


        println(addByA(10)(10)
    }
}

函数柯里化

把一个参数列表的多个参数,变成多个参数列表

def addByA(a: Int): Int => Int = a + _
//柯里化:
    def addCurrying(a: Int)(b: Int): Int = {
        a + b
   }
    println(addCurrying(32)(21))

递归(更消耗计算机资源)

递归算法

1.方法调用自身

2.方法必须要有跳出的逻辑

3.方法调用自身时,传递的参数应该有规律

4.Scala中的递归必须声明函数返回值

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

        //递归阶乘
        def fact(n: Int): Int = {
            if(n == 0) return 1
            fact(n - 1) * n
         }
        //尾递归:让loop栈每次被自己所覆盖
        def tailFact(n: Int): Int = {
            @tailrec //注解,判断是否写正确
            def loop(n: Int, currRes: Int): Int = {
                if(n == 0) return currRes
                loop(n - 1,currRes * n)
            }
            loop(n, 1)
        }
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值