事件循環(huán)和回調(diào)隊(duì)列的實(shí)戰(zhàn)理解

通過一道常見的題目蚪拦,解釋事件循環(huán)和回調(diào)隊(duì)列機(jī)制

async function async1(){
  console.log('async1 start')
  await async2()
  console.log('async1 end')
}
async function async2(){
  console.log('async2')
}
console.log('script start')
setTimeout(function(){
  console.log('setTimeout') 
},0)  
async1();
new Promise(function(resolve){
  console.log('promise1')
  resolve();
}).then(function(){
  console.log('promise2')
})
console.log('script end')

在Chrome 66和node v10中杖剪,此題的正確輸出是:

script start
async1 start
async2
promise1
script end
promise2
async1 end
setTimeout

知識點(diǎn)

  • 宏任務(wù)
    一般包括包括:整體代碼script,setTimeout驰贷,setInterval盛嘿,setImmediate,MessageChannel
  • 微任務(wù)
    一般包括:Promise括袒,process.nextTick
  • 執(zhí)行順序
    首先在 宏任務(wù)的隊(duì)列(這個隊(duì)列也被叫做 task queue)中取出第一個任務(wù)次兆,執(zhí)行完畢后取出微任務(wù)隊(duì)列中的所有任務(wù)順序執(zhí)行;之后再取一個宏任務(wù)锹锰,周而復(fù)始芥炭,直至兩個隊(duì)列的任務(wù)都取完。
  • 優(yōu)先級
    ?1. 宏任務(wù)的優(yōu)先級:主代碼塊 > setImmediate > MessageChannel > setTimeout / setInterval
    ?2. 微任務(wù)的優(yōu)先級:process.nextTick > Promise > MutationObserver
  • Promise
    ?1. Promise一旦被定義恃慧,就會立即執(zhí)行园蝠。
    ?2. Promise的reject和resolve是異步執(zhí)行的回調(diào)。所以痢士,resolve()會被放到回調(diào)隊(duì)列中
  • async/await
    ?1. await執(zhí)行完后彪薛,會讓出線程。
    ?2. async標(biāo)記的函數(shù)會返回一個Promise對象

難點(diǎn)

為了便于理解,async1函數(shù)可以理解為以下方式:

async function async1(){
  console.log('async1 start')
  async2().then( () => {
    console.log( 'async1 end ')
  })
}

流程

  1. console.log('script start')輸出:script start
  2. setTimeout被放在最后調(diào)用
  3. 執(zhí)行async1函數(shù)善延,輸出async1 start训唱。然后,進(jìn)入async2函數(shù)挚冤,輸出async2况增,并返回Promise對象⊙档玻回到async1澳骤,由于await,讓出線程澜薄,async2函數(shù)返回的Promise放在回調(diào)隊(duì)列为肮。
  4. 新new了一個Promise對象,輸出promise1肤京。其中的resolve()被放在回調(diào)隊(duì)列颊艳。
  5. console.log('script end')輸出:script end
  6. 執(zhí)行回調(diào)隊(duì)列中,async1返回的Promise對象忘分,對象產(chǎn)生的resolve被放入對調(diào)隊(duì)列棋枕。這里不輸出任何值。
  7. 執(zhí)行回調(diào)隊(duì)列中妒峦,下方Promise顯式聲明的resolve重斑,輸出promise2。
  8. 執(zhí)行回調(diào)隊(duì)列中肯骇,由于async1函數(shù)返回的promise對象的resolve窥浪,輸出async1 end。
  9. 執(zhí)行回調(diào)隊(duì)列中笛丙,最后的setTimeout漾脂,輸出setTimeout
  10. 完成
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市胚鸯,隨后出現(xiàn)的幾起案子骨稿,更是在濱河造成了極大的恐慌,老刑警劉巖蠢琳,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件啊终,死亡現(xiàn)場離奇詭異,居然都是意外死亡傲须,警方通過查閱死者的電腦和手機(jī)蓝牲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來泰讽,“玉大人例衍,你說我怎么就攤上這事昔期。” “怎么了佛玄?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵硼一,是天一觀的道長。 經(jīng)常有香客問我梦抢,道長般贼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任奥吩,我火速辦了婚禮哼蛆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘霞赫。我一直安慰自己腮介,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布端衰。 她就那樣靜靜地躺著叠洗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪旅东。 梳的紋絲不亂的頭發(fā)上灭抑,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天,我揣著相機(jī)與錄音玉锌,去河邊找鬼名挥。 笑死,一個胖子當(dāng)著我的面吹牛主守,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播榄融,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼参淫,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了愧杯?” 一聲冷哼從身側(cè)響起涎才,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎力九,沒想到半個月后耍铜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡跌前,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年棕兼,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抵乓。...
    茶點(diǎn)故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡伴挚,死狀恐怖靶衍,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情茎芋,我是刑警寧澤颅眶,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站田弥,受9級特大地震影響涛酗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜偷厦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一商叹、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沪哺,春花似錦沈自、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至籍滴,卻和暖如春酪夷,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背孽惰。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工晚岭, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人勋功。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓坦报,卻偏偏與公主長得像,于是被迫代替她去往敵國和親狂鞋。 傳聞我的和親對象是個殘疾皇子片择,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內(nèi)容