溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

每天學(xué)一點(diǎn)Scala之 Currying函數(shù)

發(fā)布時(shí)間:2020-07-02 10:57:49 來(lái)源:網(wǎng)絡(luò) 閱讀:376 作者:故新 欄目:建站服務(wù)器

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

形式




向AI問一下細(xì)節(jié)

免責(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)容。

AI