国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

JavaScript實現指定數量的并發限制的示例代碼

瀏覽:99日期:2023-11-07 17:00:31

在網上看到這么一道題:

JavaScript實現指定數量的并發限制的示例代碼

這道題跟魚頭這篇記錄『什么是時間分片(Time Slicing)? 』有點相似,但不同的是這次是限制異步并發的數量。

所以話不多說,我們先來康康實現

首先我們來實現一個分割數組的函數~

const group = (list = [], max = 0) => { if (!list.length) { return list } let results = [] for (let i = 0, len = list.length; i < len; i += max) { results.push(list.slice(i, i + max)) } return results}

這里就是根據指定的并發數量來分割數組。主要就是 for + slice ,這沒啥好說的

接下來我們再來一個用 async + await 實現的請求集合封裝。

我們通過 for...of 去遍歷每一個異步函數,然后用 async + await 確保函數的執行順序,再用 try...catch 來保證即使 reject 報錯也不會導致無法繼續執行任務。

const requestHandler = async ( groupedUrl = [], callback = () => { }) => { if (!groupedUrl.length) { callback() return groupedUrl } const newGroupedUrl = groupedUrl.map(fn => fn()) const resultsMapper = (results) => results.map(callback) const data = await Promise.allSettled(newGroupedUrl).then(resultsMapper) return data;}

接下來就是主函數

const sendRequest = async ( urls = [], max = 0, callback = () => { }) => { if (!urls.length) { return urls } const groupedUrls = group(urls, max) const results = [] console.log(’start !’) for (let groupedUrl of groupedUrls) { try { const result = await requestHandler(groupedUrl, callback) results.push(result) console.log(’go’) } catch { } } console.log(’done !’) return results}

這里就是利用了 for + async + await 來限制并發。等每次并發任務結果出來之后再執行下一次的任務。

我們執行下栗子:

const p1 = () => new Promise((resolve, reject) => setTimeout(reject, 1000, ’p1’))const p2 = () => Promise.resolve(2)const p3 = () => new Promise((resolve, reject) => setTimeout(resolve, 2000, ’p3’))const p4 = () => Promise.resolve(4)const p5 = () => new Promise((resolve, reject) => setTimeout(reject, 2000, ’p5’))const p6 = () => Promise.resolve(6)const p7 = () => new Promise((resolve, reject) => setTimeout(resolve, 1000, ’p7’))const p8 = () => Promise.resolve(8)const p9 = () => new Promise((resolve, reject) => setTimeout(reject, 1000, ’p9’))const p10 = () => Promise.resolve(10)const p11 = () => new Promise((resolve, reject) => setTimeout(resolve, 2000, ’p10’))const p12 = () => Promise.resolve(12)const p13 = () => new Promise((resolve, reject) => setTimeout(reject, 1000, ’p11’))const p14 = () => Promise.resolve(14)const ps = [p1, p2, p3, p4, p5, p6, p7, p8, p9, p10, p11, p12, p13, p14]sendRequest(ps, 3, ({reason, value}) => { console.log(reason || value)})

JavaScript實現指定數量的并發限制的示例代碼

OK,我們看到結果是如我們所愿的

到此這篇關于JavaScript實現指定數量的并發限制的示例代碼的文章就介紹到這了,更多相關JavaScript 指定數量并發限制內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产精品自拍在线 | 久久99久久99精品免观看 | 亚洲综色| 真人一级毛片全部免 | 怡红院成人永久免费看 | 美美女高清毛片视频免费观看 | 久久国内精品自在自线观看 | 一级做a级爰片性色毛片视频 | 九九在线观看视频 | 初爱视频教程在线观看高清 | 日韩偷拍自拍 | 777色狠狠一区二区三区 | 九九九九视频 | 黄 色 成 年人网站 黄 色 免费网 站 成 人 | 国产在线日韩在线 | 最新中文字幕乱码在线 | 欧美人成片免费看视频不卡 | 狠狠色婷婷丁香综合久久韩国 | 午夜日本一区二区三区 | 69xxxx欧美老师 | 99久久99久久精品免费看子 | 成人欧美视频在线看免费 | 欧美操操操| 日韩在线亚洲 | 波多野一区二区 | 亚洲欧美在线一区二区 | 激情综 | 农村寡妇一级毛片免费看视频 | 精品一区二区三区中文字幕 | 亚洲综合图片人成综合网 | 久久久毛片免费全部播放 | 特级无码a级毛片特黄 | 日本成人免费观看 | 永久黄网站色视频免费观看99 | 毛片直接看 | 国产欧美日本亚洲精品五区 | 国产一区日韩二区欧美三 | 在线欧美一级毛片免费观看 | 99秒拍福利大尺度视频 | 美国一级毛片免费看成人 | 99激情|