亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

JS異步宏隊列與微隊列原理區別詳解

瀏覽:91日期:2024-05-01 17:33:20

1. 原理圖

JS異步宏隊列與微隊列原理區別詳解

2. 說明

JS 中用來存儲待執行回調函數的隊列包含 2 個不同特定的列隊

宏列隊:用來保存待執行的宏任務(回調),比如:定時器回調、DOM 事件回調、ajax 回調 微列隊:用來保存待執行的微任務(回調),比如:promise的回調、MutationObserver 的回調

JS 執行時會區別這 2 個隊列

JS 引擎首先必須先執行所有的初始化同步任務代碼 每次準備取出第一個宏任務執行前, 都要將所有的微任務一個一個取出來執行,也就是優先級比宏任務高,且與微任務所處的代碼位置無關

下面這個例子可以看出Promise要先于setTimeout執行:

setTimeout(() => { //立即放入宏隊列 console.log(’timeout callback1()’) Promise.resolve(3).then( value => { //立即放入微隊列 console.log(’Promise onResolved3()’, value) } ) }, 0) setTimeout(() => { //立即放入宏隊列 console.log(’timeout callback2()’) }, 0) Promise.resolve(1).then( value => { //立即放入微隊列 console.log(’Promise onResolved1()’, value) setTimeout(() => { console.log(’timeout callback3()’, value) }, 0) } ) Promise.resolve(2).then( value => { //立即放入微隊列 console.log(’Promise onResolved2()’, value) } ) // Promise onResolved1() 1 // Promise onResolved2() 2 // timeout callback1() // Promise onResolved3() 3 // timeout callback2() // timeout callback3() 1

3. 相關題目

代碼一:

// 3 7 4 1 2 5 /* 宏: [] 微: [] */ const first = () => (new Promise((resolve, reject) => { console.log(3) let p = new Promise((resolve, reject) => { console.log(7) setTimeout(() => { console.log(5) resolve(6) //會被忽略,因為會先執行微隊列里的resolve(1),此時狀態已經改變過了,且狀態只能改變一次 }, 0) resolve(1) }) resolve(2) p.then((arg) => { console.log(arg) }) })) first().then((arg) => { console.log(arg) }) console.log(4)

代碼二:

// 1 7 2 3 8 4 6 5 0 setTimeout(() => { console.log('0') }, 0) new Promise((resolve, reject) => { console.log('1') resolve() }).then(() => { console.log('2') new Promise((resolve, reject) => { console.log('3') resolve() }).then(() => { console.log('4') }).then(() => { console.log('5') }) }).then(() => { console.log('6') }) new Promise((resolve, reject) => { console.log('7') resolve() }).then(() => { console.log('8') })

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 欧美日韩不卡视频一区二区三区 | 777欧美午夜精品影院 | 婷婷综合国产激情在线 | 色播亚洲视频在线观看 | 成人自拍视频 | 99久久国产综合精品麻豆 | 国产精品午夜高清在线观看 | bt7086 福利二区 最新合集 | 日韩亚洲精品不卡在线 | 亚洲欧美日韩高清一区二区三区 | 色婷婷亚洲十月十月色天 | 国产一区三区二区中文在线 | 亚洲精品一区国产二区 | 国产一区二区三区手机在线观看 | 欧美成人香蕉网在线观看 | 亚洲 欧美 国产另类首页 | 成人黄色免费观看 | 亚洲国产日韩欧美一区二区三区 | 国产一级性片 | 欧美日韩午夜精品不卡综合 | 久99久爱精品免费观看视频 | 国产a级免费| 韩国美女激情视频一区二区 | 亚洲一区精品在线 | 黄 在线| 午夜亚洲 | 亚韩在线 | 精品在线一区二区三区 | 国产caoni111在线观看视频 | 欧美狠狠入鲁的视频极速 | 天堂素人搭讪系列嫩模在线观看 | 91视频日本| 国产91高清在线 | 国产丝袜制服在线 | 美国一级大黄一片免费zzz | 美国黄色一级大片 | 午夜羞羞视频在线观看 | 免费国产一区二区三区 | 精品国产免费人成网站 | 欧美猛妇色xxxxxbbbb | 欧美特级一级毛片 |