摘要:更安全地藏私房錢實際上,每天記錄下當前的數(shù)據(jù)是不靈活的,而函數(shù)柯里化則有效地解決了這個問題。而且不定時舉辦活動贈送書籍哦
什么是函數(shù)柯里化
在計算機科學中,柯里化(Currying)是把接受多個參數(shù)的函數(shù)變換成接受一個單一參數(shù)(最初函數(shù)的第一個參數(shù))的函數(shù),并且返回接受余下的參數(shù)且返回結(jié)果的新函數(shù)的技術。這個技術由 Christopher Strachey 以邏輯學家 Haskell Curry 命名的,盡管它是 Moses Schnfinkel 和 Gottlob Frege 發(fā)明的。
舉個例子,假設程序員A是個妻管嚴,工資悉數(shù)上交給妻子,為了買一個心愛的鍵盤
程序員A每天都偷偷藏幾毛錢,打算年底買個鍵盤,因此程序員A寫了以下這個方法用來統(tǒng)計年終一共湊了多少錢,方法如下:
/** * @description 統(tǒng)計金額 * @return {number} */ function countMoney() { let money = 0 // 溫馨提示:arguments是所接收的所有參數(shù)組成的類數(shù)組,不懂的需要搜一搜補補知識啦 for (let i = 0; i < arguments.length; i++) { money += arguments[i] } return money } // 藏了一年的賬本記錄的數(shù)據(jù) const records = [1, 1, 2, 2, 3, 3, 4, 4] // 把全部數(shù)據(jù)都輸入進行計算 countMoney(1, 1, 2, 2, 3, 3, 4, 4)
上面代碼所呈現(xiàn)的方法,是最直接的計算方法,其不方便的地方在于,程序員A還要拿個小本本把每天存了多少錢先記錄下來?。?!萬一這個本子被發(fā)現(xiàn)那就少不了跪鍵盤了,極度不安全。
實際上,每天記錄下當前的數(shù)據(jù)是不靈活的,而函數(shù)柯里化則有效地解決了這個問題。
我們想要這樣存儲我們的私房錢
// 2018-01-01 存了1毛錢 countMoney(1) // 2018-01-02 存了2毛錢 countMoney(2) // 2018-01-03 存了3毛錢 countMoney(3) // 2018-01-04 存了4毛錢 countMoney(4) //一年以后 // 統(tǒng)計這筆巨額存款 countMoney()
上述的這種方法中,我們不關心數(shù)據(jù)的存儲記錄,我們只需要每天往存錢罐里面塞錢,然后年底取出來就是一個總和。再也不擔心留下小本本作為證據(jù)了!
函數(shù)柯里化代碼的實現(xiàn)/** * @description countMoney為立即執(zhí)行函數(shù),返回的結(jié)果是另一個函數(shù) */ const countMoney = (function () { let money = 0 let args = [] const res = function () { if (arguments.length === 0) { for (let i = 0; i < args.length; i++) { money += args[i] } return money } else { // arguments 是個類數(shù)組來著,應該用展開符展開才能push進去 args.push(...arguments) return res } } return res })() // 2018-01-01 存了1毛錢 countMoney(1) // 2018-01-02 存了2毛錢 countMoney(2) // 2018-01-03 存了3毛錢 countMoney(3) // 2018-01-04 存了4毛錢 countMoney(4) //一年以后 // 統(tǒng)計這筆巨額存款 輸出結(jié)果為 10 console.log(countMoney()) // 你還可以裝逼地進行花式統(tǒng)計,結(jié)果同樣是10 countMoney(1)(2)(3)(4)()分析代碼
實際上,在JavaScript的很多思想和設計模式中,閉包是個很常見且很重要的東西,上述的代碼中,本質(zhì)上就是利用了閉包。
該函數(shù)是個立即執(zhí)行函數(shù),返回了一個新函數(shù),而這個新函數(shù)實際上就是一個閉包,這個新函數(shù)把每次接收到的參數(shù)都存儲起來,
并且繼續(xù)返回一個新函數(shù),當發(fā)現(xiàn)某次調(diào)用的時候沒有傳入?yún)?shù),那就意味著要進行數(shù)據(jù)統(tǒng)計,從而把之前存儲的數(shù)據(jù)一次性拿
出來計算,最后返回計算結(jié)果。其流程如下:
所謂的函數(shù)柯里化,亦或者在開發(fā)中涉及到的其他一些概念,例如閉包、單例模式、觀察者模式等等都好,我們需要關注的點在于掌握
這些模式或者概念中的代碼設計思想,從而更好地服務于我們的業(yè)務開發(fā),讓我們的代碼更健壯、靈活、高效。
獲取更多知識,請微信掃碼關注公眾號關注早讀君,每天早晨為你推送前端知識,度過擠地鐵坐公交的時光。
而且不定時舉辦活動贈送書籍哦
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/52850.html
摘要:更安全地藏私房錢實際上,每天記錄下當前的數(shù)據(jù)是不靈活的,而函數(shù)柯里化則有效地解決了這個問題。而且不定時舉辦活動贈送書籍哦 什么是函數(shù)柯里化 在計算機科學中,柯里化(Currying)是把接受多個參數(shù)的函數(shù)變換成接受一個單一參數(shù)(最初函數(shù)的第一個參數(shù))的函數(shù),并且返回接受余下的參數(shù)且返回結(jié)果的新函數(shù)的技術。這個技術由 Christopher Strachey 以邏輯學家 Haskell ...
摘要:原文鏈接和都支持函數(shù)的柯里化函數(shù)的柯里化還與的函數(shù)編程有很大的聯(lián)系如果你感興趣的話可以在這些方面多下功夫了解相信收獲一定很多看本篇文章需要知道的一些知識點函數(shù)部分的閉包高階函數(shù)不完全函數(shù)文章后面有對這些知識的簡單解釋大家可以看看什么是柯里化 原文鏈接 Haskell和scala都支持函數(shù)的柯里化,JavaScript函數(shù)的柯里化還與JavaScript的函數(shù)編程有很大的聯(lián)系,如果你感興...
摘要:作為函數(shù)式編程語言,帶來了很多語言上的有趣特性,比如柯里化和反柯里化。個人理解不知道對不對延遲執(zhí)行柯里化的另一個應用場景是延遲執(zhí)行。不斷的柯里化,累積傳入的參數(shù),最后執(zhí)行。 作為函數(shù)式編程語言,JS帶來了很多語言上的有趣特性,比如柯里化和反柯里化。 這里可以對照另外一篇介紹 JS 反柯里化 的文章一起看~ 1. 簡介 柯里化(Currying),又稱部分求值(Partial Evalu...
摘要:作為函數(shù)式編程語言,帶來了很多語言上的有趣特性,比如柯里化和反柯里化。在一些函數(shù)式編程語言中,會定義一個特殊的占位變量。個人理解不知道對不對延遲執(zhí)行柯里化的另一個應用場景是延遲執(zhí)行。不斷的柯里化,累積傳入的參數(shù),最后執(zhí)行。作為函數(shù)式編程語言,JS帶來了很多語言上的有趣特性,比如柯里化和反柯里化。 這里可以對照另外一篇介紹 JS 反柯里化 的文章一起看~ 1. 簡介 柯里化(Currying)...
摘要:函數(shù)式編程,一看這個詞,簡直就是學院派的典范。所以這期周刊,我們就重點引入的函數(shù)式編程,淺入淺出,一窺函數(shù)式編程的思想,可能讓你對編程語言的理解更加融會貫通一些。但從根本上來說,函數(shù)式編程就是關于如使用通用的可復用函數(shù)進行組合編程。 showImg(https://segmentfault.com/img/bVGQuc); 函數(shù)式編程(Functional Programming),一...
閱讀 1281·2021-11-17 09:33
閱讀 1753·2021-09-09 11:53
閱讀 3230·2021-09-04 16:45
閱讀 1407·2021-08-17 10:12
閱讀 2399·2019-08-30 15:55
閱讀 1784·2019-08-30 15:53
閱讀 2415·2019-08-30 15:52
閱讀 2564·2019-08-29 18:41