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

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript實(shí)現(xiàn)指定數(shù)量的并發(fā)限制的示例代碼

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

在網(wǎng)上看到這么一道題:

JavaScript實(shí)現(xiàn)指定數(shù)量的并發(fā)限制的示例代碼

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

所以話不多說(shuō),我們先來(lái)康康實(shí)現(xiàn)

首先我們來(lái)實(shí)現(xiàn)一個(gè)分割數(shù)組的函數(shù)~

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}

這里就是根據(jù)指定的并發(fā)數(shù)量來(lái)分割數(shù)組。主要就是 for + slice ,這沒(méi)啥好說(shuō)的

接下來(lái)我們?cè)賮?lái)一個(gè)用 async + await 實(shí)現(xiàn)的請(qǐng)求集合封裝。

我們通過(guò) for...of 去遍歷每一個(gè)異步函數(shù),然后用 async + await 確保函數(shù)的執(zhí)行順序,再用 try...catch 來(lái)保證即使 reject 報(bào)錯(cuò)也不會(huì)導(dǎo)致無(wú)法繼續(xù)執(zhí)行任務(wù)。

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;}

接下來(lái)就是主函數(shù)

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 來(lái)限制并發(fā)。等每次并發(fā)任務(wù)結(jié)果出來(lái)之后再執(zhí)行下一次的任務(wù)。

我們執(zhí)行下栗子:

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實(shí)現(xiàn)指定數(shù)量的并發(fā)限制的示例代碼

OK,我們看到結(jié)果是如我們所愿的

到此這篇關(guān)于JavaScript實(shí)現(xiàn)指定數(shù)量的并發(fā)限制的示例代碼的文章就介紹到這了,更多相關(guān)JavaScript 指定數(shù)量并發(fā)限制內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 我要看三级毛片 | 亚洲日本激情 | 一区二区三区视频网站 | 欧美日本一区二区三区 | 人成免费a级毛片 | 国产久草视频 | 国产成人欧美一区二区三区的 | 国产亚洲精品久久麻豆 | 亚洲国产成人精品一区二区三区 | 男女交性拍拍拍高清视频 | 国产在线观看免费一级 | 国产精品美女免费视频大全 | 免费观看亚洲 | 中文字幕久久亚洲一区 | 中文字幕在线观看91 | 免费视频久久久 | 91久久综合九色综合欧美98 | 国产高清视频免费观看 | 黄色一级a毛片 | 国产亚洲欧洲一区二区三区 | 一区二区中文字幕亚洲精品 | 国产草草影院ccyycom软件 | 成人午夜兔费观看网站 | 亚洲欧美中文字幕在线网站 | 欧美高清亚洲欧美一区h | 国产精品欧美一区二区 | 91国内视频在线观看 | 福利岛国深夜在线 | 国产系列 视频二区 | 手机在线毛片 | 在线亚洲精品国产成人二区 | 国产精品亚洲片夜色在线 | 99精品视频在线观看re | 伊人狠狠丁香婷婷综合色 | 成人免费手机在线看网站 | 成人性视频免费网站 | 国产一区二区三区在线免费 | 毛片网站免费在线观看 | 99国内精品久久久久久久 | 欧美一级看片免费观看视频在线 | 爱视频福利广场 |