Coursera---Scala课程 第二周笔记


Higher-Order Functions

     这被称为“高阶函数”,既可以当参数传,也可以当返回值。
 最早的形式

def sum(f: Int => Int, a: Int, b: Int): Int =
     if (a > b) 0
else f(a) + sum(f, a + 1, b)

def sumInts(a: Int, b: Int) = sum(id, a, b)
def sumCubes(a: Int, b: Int) = sum(cube, a, b)
def sumFactorials(a: Int, b: Int) = sum(fact, a, b)

def id(x: Int): Int = x
def cube(x: Int): Int = x * x * x
def fact(x: Int): Int = if (x == 0) 1 else fact(x - 1)

 Anonymous(匿名函数)

        例如: (x: Int) => x * x * x 

        下面是匿名函数的定义形式:

               (x1 : T1; :::; xn : Tn) ) E

        等价于

               {def f(x1 : T1; :::; xn : Tn) = E; f }

         匿名函数的形式          

def sumInts(a: Int, b: Int) = sum(x => x, a, b)
def sumCubes(a: Int, b: Int) = sum(x => x * x * x, a, b)
def sumFactorials(a: Int, b: Int) = sum(fact, a, b)  



Currying

      柯里化

返回函数的函数   

     例如:

         def sum(f: Int => Int): (Int, Int) => Int = {
              def sumF(a: Int, b: Int): Int =
              if (a > b) 0
                   else f(a) + sumF(a + 1, b)
               sumF
          }

     然后可以def这么定义:

     def sumInts = sum(x => x)
     def sumCubes = sum(x => x * x * x)
     def sumFactorials = sum(fact)

    也可以用值定义

 

             val sumInts = sum(x => x)
             val sumCubes = sum(x => x * x * x)
             val sumFactorials = sum(fact)

    如何使用?

          sumCubes(1, 10) + sumFactorials(10, 20)

    对于这种返回函数的函数,Scala有专门的符合来来编程:

def sum(f: Int => Int)(a: Int, b: Int): Int =
if (a > b) 0 else f(a) + sum(f)(a + 1, b)




    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值