欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript函數(shù)式編程(Functional Programming)純函數(shù)用法分析

 更新時(shí)間:2019年05月22日 08:49:59   作者:longzhoufeng  
這篇文章主要介紹了JavaScript函數(shù)式編程(Functional Programming)純函數(shù)用法,結(jié)合實(shí)例形式分析了javascript函數(shù)式編程中純函數(shù)的函數(shù)依賴、所指透明等概念相關(guān)原理及使用技巧,需要的朋友可以參考下

本文實(shí)例講述了JavaScript函數(shù)式編程(Functional Programming)純函數(shù)用法。分享給大家供大家參考,具體如下:

函數(shù)式編程鼓勵(lì)我們多創(chuàng)建純函數(shù)(pure functions),純函數(shù)只依賴你交給它的東西,不使用任何函數(shù)以外的東西,也不會(huì)影響到函數(shù)以外的東西。跟純函數(shù)對(duì)應(yīng)的就是不純函數(shù)(impure functions),也就是不純函數(shù)可能會(huì)使用函數(shù)以外的東西,比如使用了一個(gè)全局變量。也可能會(huì)影響到函數(shù)以外的東西,比如改變了一個(gè)全局變量的值。

多使用純屬函數(shù)是因?yàn)樗煽恳恍?,也沒(méi)什么副作用(side effects)。你交給它同樣的值,它每次都會(huì)給你輸出同樣的結(jié)果,這種特質(zhì)叫所指透明(Referential transparency) 。這會(huì)讓程序更穩(wěn)定,也更容易測(cè)試。

副作用

純函數(shù)沒(méi)副作用,有副作用的函數(shù)都不純。我吃了一片感冒藥,是要治我的感冒,但副作用是它讓我想睡覺(jué)。函數(shù)的副作用多數(shù)表現(xiàn)為函數(shù)依賴或者改變了它以外的東西。

看個(gè)例子:

let name = 'longzhoufeng'
const greet = () => {
 console.log(`hello, ${name}`)
}

greet 不是純函數(shù),因?yàn)檫@個(gè)函數(shù)依賴函數(shù)以外的東西,這里就是全局作用域下的 name。這樣做的問(wèn)題是,函數(shù)依賴的 name 很可能在應(yīng)用運(yùn)行的時(shí)候發(fā)生變化,這樣試一下:

greet() // 輸出:“hello, longzhoufeng”
let name = 'longzhoupeng' // name 的值被改變了
greet() // 輸出:“hello, longzhoupeng”

這樣改一下:

const greet = (name) => {
 console.log(`hello, ${name}`)
}

現(xiàn)在函數(shù)明確的說(shuō)明了自己需要的東西,這里就是 name 參數(shù)。它現(xiàn)在只依賴你交給它的 name 參數(shù)的值。但是這個(gè)函數(shù)仍然不是純函數(shù),因?yàn)樗诳刂婆_(tái)上輸出了東西,這其實(shí)改變了函數(shù)之外的東西,所以它不是純函數(shù)。這樣再改一下:

const greet = (name) => {
 return `hello, ${name}`
}

現(xiàn)在 greet 就會(huì)是一個(gè)純函數(shù),因?yàn)樗灰蕾嚱唤o它的 name ,也沒(méi)有改變函數(shù)以外的東西。而且你每次給它同樣的 name 值,它每次都會(huì)給我們返回同樣的結(jié)果。這種函數(shù)用起來(lái)即安全又可靠。

所指透明

所指透明(Referential transparency)。比如我說(shuō):“中國(guó)的首都”。我的表達(dá)所指的意思就是 “北京”,沒(méi)什么其它的隱含的意思。所以可以說(shuō)我的表達(dá)所指是透明的(Referentially transparent)。再比如:“我有點(diǎn)餓”。這個(gè)表達(dá)所指就不透明,我表達(dá)的到底是什么意思是不能確定的,我可能是想出去吃點(diǎn)東西,也可能是想讓你幫我買點(diǎn)東西回來(lái)吃。

純函數(shù)所指的東西都是透明的,因?yàn)槟憬o它同樣的東西,它每次都會(huì)返回一樣的結(jié)果。

const greet = (name) => {
 return `hello, ${name}`
}
const logger = (message) => {
 console.log(message)
}
logger(greet('longzhoufeng'))
// 上面的表達(dá)式也可以這樣:
logger('hello, longzhoufeng')
// 得到的結(jié)果是一樣的,因?yàn)?greet 所指透明。
// 給它一個(gè) “l(fā)ongzhoufeng”,它所指的東西就是 “hello, longzhoufeng”

因?yàn)?greet 所指透明,所以如果我們?cè)诒磉_(dá)式中把它替換成它所指的東西,不會(huì)影響到程序的運(yùn)行。比如在一個(gè)表達(dá)式里所有使用 greet('longzhoufeng') 的地方,我們都可以把 greet('longzhoufeng') 替換成 hello, longzhoufeng,這是因?yàn)?greet('longzhoufeng') 所指的東西就是字符串 hello, longzhoufeng 。

參考資料

http://stackoverflow.com/questions/210835/what-is-referential-transparency

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論