溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Node事件循環(huán)中的微任務隊列是什么

發(fā)布時間:2023-04-14 09:40:30 來源:億速云 閱讀:130 作者:iii 欄目:web開發(fā)

這篇文章主要介紹“Node事件循環(huán)中的微任務隊列是什么”,在日常操作中,相信很多人在Node事件循環(huán)中的微任務隊列是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Node事件循環(huán)中的微任務隊列是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

Node事件循環(huán)中的微任務隊列是什么

// index.js
console.log("console.log 1");
process.nextTick(() => console.log("this is process.nextTick 1"));
console.log("console.log 2");

這段代碼,記錄了三個不同的語句。第二個語句使用 process.nextTick() 將回調(diào)函數(shù)排入 nextTick 隊列。

可視化

Node事件循環(huán)中的微任務隊列是什么

console.log 1
console.log 2
this is process.nextTick 1

推論

所有用戶編寫的同步 JavaScript 代碼優(yōu)先于異步代碼執(zhí)行。

讓我們繼續(xù)進行第二個實驗。

實驗二

代碼

// index.js
Promise.resolve().then(() => console.log("this is Promise.resolve 1"));
process.nextTick(() => console.log("this is process.nextTick 1"));

我們有一個 Promise.resolve().then() 調(diào)用和一個 process.nextTick() 調(diào)用。

可視化

Node事件循環(huán)中的微任務隊列是什么

this is process.nextTick 1
this is Promise.resolve 1

推論

nextTick 隊列中的所有回調(diào)函數(shù)優(yōu)先于 Promise 隊列中的回調(diào)函數(shù)執(zhí)行。

讓我?guī)阕咭槐樯鲜龅诙€實驗的更詳細版本。

福利實驗

代碼

// index.js
process.nextTick(() => console.log("this is process.nextTick 1"));
process.nextTick(() => {
  console.log("this is process.nextTick 2");
  process.nextTick(() =>
    console.log("this is the inner next tick inside next tick")
  );
});
process.nextTick(() => console.log("this is process.nextTick 3"));

Promise.resolve().then(() => console.log("this is Promise.resolve 1"));
Promise.resolve().then(() => {
  console.log("this is Promise.resolve 2");
  process.nextTick(() =>
    console.log("this is the inner next tick inside Promise then block")
  );
});
Promise.resolve().then(() => console.log("this is Promise.resolve 3"));

該代碼包含三個 process.nextTick() 調(diào)用和三個 Promise.resolve() 調(diào)用語句。每個回調(diào)函數(shù)記錄適當?shù)南ⅰ?/p>

但是,第二個 process.nextTick() 和第二個 Promise.resolve() 都有一個額外的 process.nextTick() 語句,每個都帶有一個回調(diào)函數(shù)。

可視化

Node事件循環(huán)中的微任務隊列是什么

this is process.nextTick 1
this is process.nextTick 2
this is process.nextTick 3
this is the inner next tick inside next tick
this is Promise.resolve 1
this is Promise.resolve 2
this is Promise.resolve 3
this is the inner next tick inside Promise then block

這可能是一個稍微高級的實驗,但推論仍然相同。

推論

nextTick 隊列中的所有回調(diào)函數(shù)優(yōu)先于 Promise 隊列中的回調(diào)函數(shù)執(zhí)行。

使用 process.nextTick() 時要小心。過度使用此方法可能會導致事件循環(huán)饑餓,從而阻止隊列中的其余部分運行。當存在大量的 nextTick() 調(diào)用時,I/O 隊列是無法執(zhí)行自己的回調(diào)函數(shù)的。官方文檔建議使用 process.nextTick() 的兩個主要場景:處理錯誤或在調(diào)用棧為空事件循環(huán)繼續(xù)之前執(zhí)行回調(diào)用。所以在使用 process.nextTick() 時,要明智一些。

到此,關(guān)于“Node事件循環(huán)中的微任務隊列是什么”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI