概念:在計(jì)算機(jī)科學(xué)中捧杉,柯里化(Currying)是把接受多個(gè)參數(shù)的函數(shù)變換成接受一個(gè)單一參數(shù)(最初函數(shù)的第一個(gè)參數(shù))的函數(shù)岂却,并且返回接受余下的參數(shù)且返回結(jié)果的新函數(shù)的技術(shù)驱证。這個(gè)技術(shù)由 Christopher Strachey 以邏輯學(xué)家 Haskell Curry 命名的羊苟,盡管它是 Moses Schnfinkel 和 Gottlob Frege 發(fā)明的艰匙。
例子如下:
比如我們有這樣的一個(gè)方法搬设,將傳入的數(shù)字進(jìn)行+1操作问麸,但是如果我們還想執(zhí)行+2伙判、+3等等操作是不是得寫(xiě)好多個(gè)這樣的方法呢?
func addOneNumber(num: Int) ->Int{
return num + 1
}
func addTwoNumber(num: Int) ->Int{
return num + 2
}
func addThreeNumber(num: Int) ->Int{
return num + 3
}
柯里化(Currying)之后
//基本的柯里化函數(shù)
func addToNumber(_ adder: Int) -> (Int) -> Int {
return { num in
return num + adder
}
}
產(chǎn)生一個(gè)以6為被加數(shù)的閉包
let addNumberTwo = addToNumber(6)
var result1 = addNumberTwo(8) // 6+ 9
var result2 = addNumberTwo(9) // 6 + 9