原創(chuàng)文章轉(zhuǎn)載請注明出處
關于函數(shù)式編程的概念這里不做深入介紹丰涉,這里要講的是函數(shù)式編程的部分應用場景峡蟋,如果下面這些內(nèi)容你都了解了,那么再去看函數(shù)式編程的介紹你就可以很快的理解了锰镀,甚至你可能發(fā)現(xiàn)自己在不知不覺中已經(jīng)使用了很多函數(shù)式編程的技巧了藤抡。
1. map盯蝴、reduce禁谦、filter...#
函數(shù)式編程最常見的技術(shù)就是對一個集合做Map显设、Reduce和Filter操作孕豹,map對集合成員做了映射操作涩盾,生成新的集合;reduce就是降維操作励背,化整為零春霍;filter顧名思義通過過濾器生成新的集合。
Python
map(lambda x: x ** 2, [1, 2, 3, 4, 5])
filter(lambda x: x & 1 != 0, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
reduce(lambda x, y: x + y, [2, 3, 4, 5, 6], 1) #((((((1+2)+3)+4)+5)+6))
Swift
[1, 2, 3, 4, 5].map { i in return i*i }
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10].filter { (i) -> Bool in return i & 1 != 0 }
[2, 3, 4, 5, 6].reduce(1) { (result, i) -> Int in return result + i }
這里不深究Swift的閉包語法叶眉,我知道尾隨閉包可以簡寫址儒。
以上兩種語言的代碼,轉(zhuǎn)換后輸出的結(jié)果都是:
[1, 4, 9, 16, 25]
[1, 3, 5, 7, 9]
21
我們將函數(shù)作為參數(shù)傳給了map/filter/reduce函數(shù)衅疙,告訴這些函數(shù)你們要對數(shù)組元素進行什么操作莲趣,而不是使用低級的循環(huán)迭代方式來操作數(shù)組元素。變量可以指向函數(shù)饱溢,函數(shù)的參數(shù)能接收變量喧伞,那么一個函數(shù)就可以接收另一個函數(shù)作為參數(shù),這種函數(shù)就稱之為高階函數(shù)
绩郎,函數(shù)式編程就是指這種高度抽象的編程范式潘鲫。
2. currying 柯里化##
柯里化 (Currying),也就是把接受多個參數(shù)的方法變換成接受第一個參數(shù)的方法肋杖,并且返回接受余下的參數(shù)而且返回結(jié)果的新方法溉仑。
Python
def inc(x):
def incx(y):
return x+y
return incx
inc2 = inc(2)
inc5 = inc(5)
print inc2(5) # 輸出 7
print inc5(5) # 輸出 10
Swift
//下面這種Currying語法在Swift 3.0已經(jīng)被移除了。
//func inc(x: Int)(y: Int) -> Int { return x + y }
//你可以這么寫兽愤,看起來跟Python的樣式比較接近
func inc(x:Int) -> ((Int) -> Int) {
return { y in
return x + y
}
}
let inc2 = inc(x: 2)
let inc5 = inc(x: 5)
print(inc2(5))
↑函數(shù)式編程的特點:把函數(shù)當成變量來用彼念。
函數(shù)式編程的應用場景還有許多,這里沒有全部列出浅萧,諸如遞歸逐沙、惰性求值(Lazy)等。也許你自己都不知道已經(jīng)在不知不覺的使用著函數(shù)式編程洼畅,看完上面的介紹是不是更能體會到函數(shù)式編程的思維邏輯吩案?
需要注意的是,F(xiàn)P(函數(shù)式編程)和FRP(函數(shù)響應式編程)是有差別的帝簇,我的理解是FRP是FP的更高級應用徘郭,F(xiàn)RP提供了一種信號機制靠益,通過信號來記錄值的變化。信號可以被疊加残揉、分割或合并胧后,通過對信號的組合,就不需要去監(jiān)聽某個值或事件抱环。至于MVVM壳快,那是一種應用FRP實現(xiàn)的開發(fā)模型,以區(qū)別于傳統(tǒng)的MVC模型镇草。比如iOS上的RAC/RxSwift都是FRP框架眶痰,可以利用RAC/RxSwift來實現(xiàn)MVVM開發(fā)模型。
我是咕咕雞梯啤,一個還在不停學習的全棧工程師竖伯。
熱愛生活,喜歡跑步因宇,家庭是我不斷向前進步的動力七婴。