欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS異步宏隊(duì)列微隊(duì)列原理詳解

 更新時(shí)間:2020年09月09日 09:58:25   作者:蔣先森  
這篇文章主要介紹了JS異步宏隊(duì)列微隊(duì)列原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

先看一張我繪制的原理圖

原理圖

setImmediate 也是宏任務(wù),在 Node 環(huán)境下,微任務(wù)還有 process.nextTick

JS 中用來存儲(chǔ)待執(zhí)行回調(diào)函數(shù)的隊(duì)列包含 2 個(gè)不同特定的列隊(duì)

  • 宏列隊(duì):用來保存待執(zhí)行的宏任務(wù)(回調(diào)),比如:定時(shí)器回調(diào)、DOM 事件回調(diào)、ajax 回調(diào)微
  • 列隊(duì):用來保存待執(zhí)行的微任務(wù)(回調(diào)),比如:promise的回調(diào)、MutationObserver 的回調(diào)

JS 執(zhí)行時(shí)會(huì)區(qū)別這 2 個(gè)隊(duì)列

  • JS 引擎首先必須先執(zhí)行所有的初始化同步任務(wù)代碼
  • 每次準(zhǔn)備取出第一個(gè)宏任務(wù)執(zhí)行前, 都要將所有的微任務(wù)一個(gè)一個(gè)取出來執(zhí)行,也就是優(yōu)先級(jí)比宏任務(wù)高,且與微任務(wù)所處的代碼位置無關(guān)

下面這個(gè)例子可以看出 Promise 要先于 setTimeout 執(zhí)行

setTimeout(() => { // 立即放入宏隊(duì)列
  console.log('settimeout callback1()');
}, 0);
setTimeout(() => { // 立即放入宏隊(duì)列
  console.log('settimeout callback2()');
}, 0);


Promise.resolve(1).then(value => { // 立即放入微隊(duì)列
  console.log('Promise onResolved1()', value);
})
Promise.resolve(2).then(value => { // 立即放入微隊(duì)列
  console.log('Promise onResolved2()', value);
})

// Promise onResolved1() 1
// Promise onResolved2() 2
// settimeout callback1()
// settimeout callback2()

全文完。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論