Swift 里可以將方法進(jìn)行柯里化 (Currying),這是也就是把接受多個(gè)參數(shù)的方法進(jìn)行一些變形讽挟,使其更加靈活的方法楣导。函數(shù)式的編程思想貫穿于 Swift 中,而函數(shù)的柯里化正是這門語言函數(shù)式特點(diǎn)的重要表現(xiàn)榛泛。
舉個(gè)例子,下面的函數(shù)簡單地將輸入的數(shù)字加 1:
func addOne(num: Int) -> Int { return num + 1}
這個(gè)函數(shù)所表達(dá)的內(nèi)容非常有限噩斟,如果我們之后還需要一個(gè)將輸入數(shù)字加 2曹锨,或者加 3 的函數(shù),可能不得不類似地去定義返回為?num + 2?或者?num + 3?的版本剃允。有沒有更通用的方法呢沛简?我們其實(shí)可以定義一個(gè)通用的函數(shù),它將接受需要與輸入數(shù)字相加的數(shù)硅急,并返回一個(gè)函數(shù)覆享。返回的函數(shù)將接受輸入數(shù)字本身,然后進(jìn)行操作:
func addTo(adder: Int) -> Int -> Int?
{
?return { num in return num + adder }
}
有了?addTo营袜,我們現(xiàn)在就能輕易寫出像是?addOne?或者?addTwo?這樣的函數(shù)了:
let addTwo = addTo(2) // addTwo: Int -> Int
let result = addTwo(6) // result = 8
再舉一個(gè)例子撒顿,我們可以創(chuàng)建一個(gè)比較大小的函數(shù):
func greaterThan(comparer: Int) -> Int -> Bool {
?return { $0 > comparer }
}
let greaterThan10 = greaterThan(10);
greaterThan10(13) // => true
greaterThan10(9) // => false
柯里化是一種量產(chǎn)相似方法的好辦法,可以通過柯里化一個(gè)方法模板來避免寫出很多重復(fù)代碼荚板,也方便了今后維護(hù)凤壁。
舉一個(gè)實(shí)際應(yīng)用時(shí)候的例子,在?Selector?一節(jié)中跪另,我們提到了在 Swift 中?Selector?只能使用字符串在生成拧抖。這面臨一個(gè)很嚴(yán)重的問題,就是難以重構(gòu)免绿,并且無法在編譯期間進(jìn)行檢查唧席,其實(shí)這是十分危險(xiǎn)的行為。但是 target-action 又是 Cocoa 中如此重要的一種設(shè)計(jì)模式嘲驾,無論如何我們都想安全地使用的話淌哟,應(yīng)該怎么辦呢?一種可能的解決方式就是利用方法的柯里化辽故。
protocol TargetAction {?
?func performAction()
}
struct TargetActionWrapper<T: AnyObject>: TargetAction {?
?weak var target: T?
?let action: (T) -> () -> ()
?func performAction() -> () {
?if let t = target { action(t)() } }}
enum ControlEvent { case TouchUpInside case ValueChanged // ...}
class Control {?
?var actions = [ControlEvent: TargetAction]()?
?func setTarget<T: AnyObject>(target: T, action: (T) -> () -> (), controlEvent: ControlEvent) { actions[controlEvent] = TargetActionWrapper( target: target, action: action) }
?func removeTargetForControlEvent(controlEvent: ControlEvent) { actions[controlEvent] = nil }?
?func performActionForControlEvent(controlEvent: ControlEvent) { actions[controlEvent]?.performAction() }}
先轉(zhuǎn)載收藏徒仓,后續(xù)需要仔細(xì)研究!