1、Curring函數(shù) 定義?
將原來(lái)接收兩個(gè)參數(shù)的一個(gè)函數(shù),轉(zhuǎn)換為兩個(gè)函數(shù),第一個(gè)函數(shù)接收原先的第一個(gè)參數(shù),然后返回接收原先第二個(gè)參數(shù)的第二個(gè)函數(shù)。
在函數(shù)調(diào)用的過程中,就變?yōu)榱藘蓚€(gè)函數(shù)連續(xù)調(diào)用的形式
在marathon源碼以及Spark的源碼中,也有體現(xiàn),所以對(duì)()()這種形式的Curring函數(shù),要理解。
2、例子:
object CurryingTest { def main(args: Array[String]): Unit = { println("---->:\t" + sum(3,4)) println("---->:\t" + sum2(5)) println("---->:\t" + sum2(5)(1)) // 柯里函數(shù) println("---->:\t" + sum3(4)(8)) } def sum(a: Int, b: Int) = a + b def sum2(a: Int) = (b: Int) => a + b // 由sum函數(shù)轉(zhuǎn)換成sum3函數(shù)時(shí)的中間過程 def sum3(a: Int)(b: Int) = a + b }
其實(shí),柯里函數(shù)到底用在什么場(chǎng)景下,并沒有真正理解。
目前,僅僅是,只要看到
sum3(a: Int)(b: Int) = a + b
這種形式,可以直接理解成 或者等價(jià)于
sum(a: Int, b: Int) = a + b
形式
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。