第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

js for 在等待時(shí)是否阻塞?

js for 在等待時(shí)是否阻塞?

湖上湖 2022-11-11 16:40:25
const somefunction = async () => {  const arr = [...]  for(let i = 0 ; i < arr.length ; ++i){    await updater(arr[i])  }}上面的 for 循環(huán)將等待 promise 解決,然后再進(jìn)行下一次迭代,但是,現(xiàn)在這是否是 nodejs 中主事件循環(huán)的阻塞操作?請注意:這是一個(gè)“for”而不是“forEach”循環(huán)。非常不一樣。
查看完整描述

2 回答

?
鳳凰求蠱

TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超4個(gè)贊

不,它沒有阻塞。

asyncawait函數(shù)在執(zhí)行承諾時(shí)進(jìn)入睡眠狀態(tài)。控制權(quán)交還給調(diào)用函數(shù)(該函數(shù)獲取從async函數(shù)返回的未解決的 Promise)。

(當(dāng)然,如果updater是阻塞,那么它仍然會(huì)阻塞)。


查看完整回答
反對 回復(fù) 2022-11-11
?
烙印99

TA貢獻(xiàn)1829條經(jīng)驗(yàn) 獲得超13個(gè)贊

正如您通過運(yùn)行此示例所看到的,該函數(shù)將是非阻塞的。這就是異步等待的本質(zhì)。


    function asyncAction(message) {

        console.log("asyncAction start: " + message)

        return new Promise ( (res, err) => {

                                            setTimeout( () => res("done"),2000)

                                            }

        )

        console.log("asyncAction complete: " + message)

    }   


    async function asyncActions() {

        await asyncAction("1")

        console.log("1 done")

        await asyncAction("2")

        console.log("2 done")

        await asyncAction("3")              

        console.log("3 done")

    }   


    console.log("program start")

    asyncActions()

    console.log("program complete")


查看完整回答
反對 回復(fù) 2022-11-11
  • 2 回答
  • 0 關(guān)注
  • 159 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)