日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解JS中的reduce fold unfold用法

瀏覽:283日期:2024-03-27 16:32:06
fold(reduce)

說說reduce吧, 很喜歡這個函數,節省了不少代碼量,而且有一些聲明式的雛形了,一些常見的工具函數,flatten,deepCopy,mergeDeep等用reduce實現的很優雅簡潔。reduce也稱為fold,本質上就是一個折疊數組的過程,把數組中的多個值經過運算變成一個值,每次運算都會有一個函數處理,這個函數就是reduce的核心元素,稱之為reducer,reducer函數是個2元函數,返回1個單值,常見的add函數就是reducer

const addReducer = (x, y) => x + y;

這個add函數就是一個reducer,最常見的用法就是結合數組的reduce方法來用

[1, 2, 3, 4, 5].reduce(addReducer, 0) // 15

為了更好的理解reduce,下面用不同的思路實現一遍這個函數

使用for...of

const reduce = (f, init, arr) => { let acc = init; for (const item of arr) { acc = f(acc, item); } return acc}// 執行reduceFor(addReducer, 0, [1, 2, 3, 4, 5]) // 15使用while循環

reduce = (f, init, arr) => { let acc = init; let current; let i = 0; while ((current = arr[i++])) { acc = f(acc, current); } return acc;}// 執行reduceFor(addReducer, 0, [1, 2, 3, 4, 5]) // 15更像fold的實現

上面的實現也都好理解,但好像沒有體現出來折疊(fold)這個過程,折疊應該是對數組的層層擠壓操作,上面的實現數組和邏輯其實是分開了,而且也引入了比較多的中間變量,雖然是在內部沒有副作用吧。其實換個思路想一下,如果把狀態通過參數來傳遞,就可以更好的體現fold的過程,這里的參數是值是指逐漸變化的數組和計算值,并可以盡可能的做到無狀態,真正純函數的實現是沒有表達式,只有語句的,這個可以用遞歸做到。下面的實現是用尾遞歸實現的reduce,可以在實現的過程中就看出數組和計算值是怎樣變化的。非常符合fold這個稱謂

function reduce(f, init, arr) { if (arr.length === 0) return init; const [head, ...rest] = arr; return reduceRecursion(f, f(init, head), rest);}// 執行reduceFor(addReducer, 0, [1, 2, 3, 4, 5]) // 15unfold

fold反過來就是unfold,unfold顧名思義就是根據一個反過來的reducer,來生成一系列的值。此時這個如果說原來的reducer實現類似于(a, b) -> c,那反過來就是c -> [a, b], 生成序列是一個很基本的操作,但就是這個基本的操作,也有很多實現的思路,在介紹unfold之前,看一下實現序列的其他方法,最后來做一個對比。

序列的實現

range(0, 100, 5)

期待結果

[0, 5, 10, ... 95]

數組實現

這個就不多說了,大家應該都知道。

range = (first, last, step) => { const n = (last - first) / step + 1; return Array.from({ length: n - 1 }) .map((_, index) => first + index * step);}// 也可以使用from的第二個參數// Array.from({ length: n }, (_, i) => first + i * step);生成器實現

生成序列還有一個利器,那就是generator,生成器生成器,就是用來生成數據的。generator返回一個迭代器,也很容易生成序列

function* range(first, last, step) { let acc = first; while (acc < last) { yield acc; acc = acc + step; }}[...range(0, 100, 5)]

兩者相比,generator更注重生成的過程,Array注重數據變化的過程。

unfold實現

在實現unfold之前,首先梳理一下實現思路,和fold一樣,也是用遞歸,且要在實現的過程中看到對應數據的變化。大體過程如下

0 -> [0, 5]

5 -> [5, 10]

10 -> [10, 15]

15 -> [15, 20]

...

90 -> [90, 95]

95 -> [95, 100]

可以看出過程恰恰是fold反過來,符合c -> [a, b]因為初始值肯定為一個數組,所以unfold只需要兩個參數,實現如下。

function unfold(f, init) { const g = (f, next, acc) => { const result = f(next); const [head, last] = result || []; console.log(last); return result ? g(f, last, acc.concat(head)) : acc; }; return g(f, init, []);}range = R.curry((first, last, step) => unfold(next => next < last && [next, next + step], 0))// 執行range(0, 100, 5)總結

以上就是結合reduce和一個生成序列的例子簡單介紹了一下fold和unfold這兩個在fp編程中很重要的概念,當然他們功能不只是生成序列,還有很多很強大的功能

以上就是詳解JS中的reduce fold unfold用法的詳細內容,更多關于JS的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美激情在线精品一区二区三区| 精品免费视频| 国产麻豆久久| 不卡一二三区| 欧美日韩免费观看视频| 亚洲成人不卡| 亚洲电影在线| 日韩亚洲国产欧美| 综合亚洲自拍| 日韩av中文字幕一区二区| 欧美一级一区| 美腿丝袜亚洲一区| 91亚洲一区| 999久久久精品国产| 99热免费精品| 亚洲狼人精品一区二区三区| 日本伊人午夜精品| 日韩欧美另类中文字幕| 青青国产91久久久久久| 日本中文字幕视频一区| 视频一区二区三区入口| 日韩午夜精品| 国产精品免费看| 黄色免费成人| 亚洲综合国产| 蜜臀av国产精品久久久久| 久久精品青草| 波多视频一区| 黄色av日韩| 免费黄网站欧美| 日本亚洲欧洲无免费码在线| 亚洲精品中文字幕99999| 久久成人一区| 日韩精品成人| 国产精品va视频| 麻豆国产精品一区二区三区| 精品一区二区三区中文字幕在线| 久久精品国产久精国产| 国产一区二区三区国产精品| 国产伦久视频在线观看| 成人精品中文字幕| 性欧美69xoxoxoxo| 伊人久久亚洲| 日本在线视频一区二区| 日韩一区二区三区精品| 亚洲精品第一| 三级亚洲高清视频| 香蕉精品999视频一区二区| 亚洲九九精品| 国产精品观看| 三级小说欧洲区亚洲区| 婷婷综合亚洲| 亚洲永久精品唐人导航网址| 97久久中文字幕| 久久精品系列| 精品美女久久| 1024精品久久久久久久久| 中文字幕一区二区三区四区久久| 国产精品自在| 日韩欧美精品一区| 视频一区二区国产| 国产亚洲精品美女久久| 国产乱人伦丫前精品视频 | 老司机精品视频网| 正在播放日韩精品| 99国产精品久久久久久久 | 九一精品国产| 日韩一区二区三区免费视频| 久久一区亚洲| 欧美a级片一区| 亚洲欧美高清| 久久av一区二区三区| 国产精品毛片久久久| 天堂√中文最新版在线| 黄色成人91| 久久wwww| 亚洲激精日韩激精欧美精品| 奇米狠狠一区二区三区| 天堂中文av在线资源库| 亚洲美女久久| 日韩综合精品| 啪啪亚洲精品| 欧美日韩一二| 欧美一区在线观看视频| 欧美精品高清| 亚洲bt欧美bt精品777| 久久精品官网| 国产探花一区二区| 国产综合婷婷| 国产亚洲久久| 99国产精品| 精品国产美女a久久9999| 尤物在线精品| 国产一区二区三区四区二区| 午夜亚洲精品| 福利一区和二区| 日韩一二三区在线观看| 成人精品中文字幕| 国产精品欧美一区二区三区不卡| 国产一区二区三区自拍| 国产福利亚洲| 蜜桃传媒麻豆第一区在线观看| 精品视频亚洲| 日本成人精品| 久久在线视频免费观看| 国产精成人品2018| 美女精品网站| 色综合www| 麻豆91小视频| 日韩中文字幕在线一区| 蜜桃国内精品久久久久软件9| 欧美激情视频一区二区三区免费 | 久久精品 人人爱| 五月婷婷亚洲| 蜜桃av.网站在线观看| 国产伦乱精品| 免费人成网站在线观看欧美高清| 激情黄产视频在线免费观看| 欧美精品国产| 亚洲欧洲日韩| 美女精品在线观看| 亚洲一级网站| 久久影院午夜精品| 美女视频一区在线观看| 日本视频在线一区| 日本黄色精品| 极品av在线| 免费亚洲一区| 欧美中文一区| 四虎精品一区二区免费| 久久亚洲视频| 欧美午夜不卡影院在线观看完整版免费| 免费在线播放第一区高清av| 日韩高清欧美激情| 综合激情视频| 蜜臀精品久久久久久蜜臀 | 国产精品日本| 欧美日韩国产一区二区三区不卡| 免费看av不卡| 国产精品毛片一区二区在线看| 国产欧美日韩精品一区二区免费| 亚洲免费福利一区| 夜夜嗨一区二区三区| 在线视频日韩| 日韩亚洲国产欧美| 黄色亚洲免费| 在线视频日韩| 国产亚洲午夜| 亚洲深爱激情| 免费人成精品欧美精品| 三级在线观看一区二区| 六月婷婷一区| 免费在线观看精品| 日韩在线卡一卡二| 男女激情视频一区| 综合国产在线| 香蕉成人久久| 久久亚洲精品伦理| 日韩亚洲在线| 天堂成人国产精品一区| 中文精品视频| 蜜桃视频免费观看一区| 亚洲一级大片| 奇米777国产一区国产二区| 奇米亚洲欧美| 国产精品欧美大片| 久久精品国产一区二区| 成人黄色av| 亚洲福利专区| 91久久午夜| 喷白浆一区二区| 国产美女久久| 欧美国产一级| 免费在线小视频| 欧美理论视频| 亚洲深深色噜噜狠狠爱网站| 奇米狠狠一区二区三区| 国产精品手机在线播放| 老司机精品视频在线播放| 高清久久一区| 国产综合激情| 综合在线一区| 欧美黄色精品| 精品丝袜在线| 亚洲激情久久| 国产精品一区高清| 肉色欧美久久久久久久免费看| 亚洲香蕉网站| 久久亚洲二区| 国产精品亚洲人成在99www| 国产成人精品999在线观看| 视频福利一区| 亚洲综合图色| 久久精品国产成人一区二区三区| 成人日韩在线| 中文字幕视频精品一区二区三区| 麻豆精品99| 日韩精品一区二区三区免费观影 | 亚洲天堂av资源在线观看| 日韩美女国产精品|