每天学一点Scala之 Currying函数

本文介绍了Curring函数的概念,即如何将一个接受多个参数的函数转换为一系列依次接受单个参数的函数。通过具体的Scala代码示例,展示了Curring函数的工作原理及如何在实际编程中应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、Curring函数 定义?

    将原来接收两个参数的一个函数,转换为两个函数,第一个函数接收原先的第一个参数,然后返回接收原先第二个参数的第二个函数。

在函数调用的过程中,就变为了两个函数连续调用的形式

在marathon源码以及Spark的源码中,也有体现,所以对()()这种形式的Curring函数,要理解。

2、例子:

1
2
3
4
5
6
7
8
9
10
11
12
object CurryingTest {
   def main(args: Array[String]): Unit = {
      println("---->:\t" + sum(3,4))
      println("---->:\t" + sum2(5))
      println("---->:\t" + sum2(5)(1))
      // 柯里函数
      println("---->:\t" + sum3(4)(8))
   }
   def sum(a: Int, b: Int) = a + b
   def sum2(a: Int) = (b: Int) => a + b  // 由sum函数转换成sum3函数时的中间过程
   def sum3(a: Int)(b: Int) = a + b
}



其实,柯里函数到底用在什么场景下,并没有真正理解。

目前,仅仅是,只要看到

1
sum3(a: Int)(b: Int) = a + b

这种形式,可以直接理解成 或者等价于 

1
sum(a: Int, b: Int) = a + b

形式















本文转自故新51CTO博客,原文链接:http://blog.51cto.com/xingej/1963456 ,如需转载请自行联系原作者




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值