1、Curring函数 定义?
将原来接收两个参数的一个函数,转换为两个函数,第一个函数接收原先的第一个参数,然后返回接收原先第二个参数的第二个函数。
在函数调用的过程中,就变为了两个函数连续调用的形式
在marathon源码以及Spark的源码中,也有体现,所以对()()这种形式的Curring函数,要理解。
2、例子:
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 }
其实,柯里函数到底用在什么场景下,并没有真正理解。
目前,仅仅是,只要看到
sum3(a: Int)(b: Int) = a + b
这种形式,可以直接理解成 或者等价于
sum(a: Int, b: Int) = a + b
形式
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。