javascript事件循環(huán)和事件隊(duì)列(瀏覽器環(huán)境)

以前對js的事件循環(huán)和事件隊(duì)列不是很明白檐春,只知道js是單線程唠椭,什么異步啊什么的,沒有深入的去了解過侧啼,所以導(dǎo)致有些時(shí)候執(zhí)行的順序不是朝著自己想當(dāng)然的執(zhí)行順序牛柒!弄的就很頭疼!所以本篇文字將記錄一下什么是事件循環(huán)和事件隊(duì)列痊乾,忘記的時(shí)候可以再回來看看多鞏固皮壁!

javascript有一個(gè)執(zhí)行棧和任務(wù)隊(duì)列,主線程將會按順序執(zhí)行代碼哪审,遇到函數(shù)的時(shí)候蛾魄,將函數(shù)入棧,執(zhí)行完函數(shù)之后再將函數(shù)彈出棧湿滓,直到所有的代碼都執(zhí)行完畢為止滴须。

在遇到有異步操作的時(shí)候如:(setTimeout,ajax)等這些叽奥,瀏覽器自己會去執(zhí)行這些異步的操作扔水,在瀏覽器執(zhí)行完這些異步的操作之后,瀏覽器會把事件定義的回調(diào)函數(shù)推入主線程的任務(wù)隊(duì)列中朝氓,在主線程執(zhí)行棧清空之后魔市,會去執(zhí)行任務(wù)隊(duì)列中的回調(diào)函數(shù),直到任務(wù)隊(duì)列清空為止赵哲,然后再回到主線程執(zhí)行棧繼續(xù)執(zhí)行待德,從而進(jìn)入一個(gè)無限循環(huán)這個(gè)就叫事件循環(huán)

image.png

分的更細(xì)一點(diǎn)

宏任務(wù)&微任務(wù)

一個(gè)瀏覽器環(huán)境只能有一個(gè)事件循環(huán),但是一個(gè)事件循環(huán)可以有多個(gè)任務(wù)隊(duì)列枫夺。
宏任務(wù):瀏覽器的渲染将宪,setTimeout,ajax,I/O等
微任務(wù):process.nextTick, Promise等
當(dāng)遇到setTimeout较坛,I/O等事件的時(shí)候印蔗,會創(chuàng)建一個(gè)宏任務(wù),當(dāng)遇到promise的時(shí)候會創(chuàng)建一個(gè)微任務(wù)丑勤,兩個(gè)分別掛起的任務(wù)隊(duì)列喻鳄。當(dāng)主線程的執(zhí)行棧閑置的時(shí)候,開始處理微任務(wù)确封,把所有的微任務(wù)處理完后除呵,再去取宏任務(wù)隊(duì)列的第一個(gè),把宏任務(wù)隊(duì)列的回調(diào)函數(shù)拖到執(zhí)行棧中執(zhí)行爪喘,返回主線程執(zhí)行棧颜曾。
每一次事件循環(huán),只會處理一個(gè)宏任務(wù)秉剑,等到微任務(wù)一次性完畢之后泛豪,再清理宏任務(wù)。在處理這些微任務(wù)的同時(shí)侦鹏,還可能會加入新的微任務(wù)诡曙,也會一一執(zhí)行完畢,直到微任務(wù)隊(duì)列清空為止略水。


image.png

下面看幾個(gè)例子:

image.png

上述代碼打印順序: 開始 -> 開始1 -> 開始2 -> 結(jié)束 -> 1 -> 2 -> 3
解析
主線程執(zhí)行棧:console.log('開始') 開始1价卤,開始2,結(jié)束渊涝。執(zhí)行setTimeout的時(shí)候?qū)⒒卣{(diào)函數(shù)添加到任務(wù)棧里面慎璧,當(dāng)主線程執(zhí)行完后,setTimeout的定時(shí)會執(zhí)行然后再根據(jù)定時(shí)的回調(diào)再清除任務(wù)棧里面的回調(diào)函數(shù)跨释。setTimeout的第二個(gè)參數(shù)時(shí)間胸私,不一定是等到多少秒后再去執(zhí)行的,否則寫0的話就變成0秒了鳖谈,這個(gè)是等主線程執(zhí)行棧為空的時(shí)候再才去執(zhí)行岁疼。


我是第二題:

image.png

打印順序:開始 -> fn1 -> ajaxfn -> 結(jié)束 -> ajaxpromise結(jié)束 -> setTimeout
解析
流程:開始-> fn1()入棧 執(zhí)行 推出棧-> setTimeout()執(zhí)行,回調(diào)函數(shù)入宏任務(wù)隊(duì)列-> ajaxfn() 入棧執(zhí)行 打印ajaxfn 返回promise缆娃,此時(shí)就有一個(gè)微任務(wù)promise添加到任務(wù)隊(duì)列里面了-> 結(jié)束 -> 此時(shí)主線程執(zhí)行棧閑置捷绒,然后開始執(zhí)行任務(wù)隊(duì)列,微任務(wù)promise開始執(zhí)行龄恋,微任務(wù)隊(duì)列清空后疙驾,然后再執(zhí)行宏任務(wù)凶伙,取出第一個(gè)并打印setTimeout郭毕。
巧記

我們只需記住當(dāng)前執(zhí)行棧執(zhí)行完畢時(shí)會立刻先處理所有微任務(wù)隊(duì)列中的事件,然后再去宏任務(wù)隊(duì)列中取出一個(gè)事件函荣。同一次事件循環(huán)中显押,微任務(wù)永遠(yuǎn)在宏任務(wù)之前執(zhí)行扳肛。

setTimeout(function () {
    console.log(1);
});

new Promise(function(resolve,reject){
    console.log(2)
    resolve(3)
}).then(function(val){
    console.log(val);
})

打印順序: 2 -> 3 -> 1
先執(zhí)行完微任務(wù)promise,然后再執(zhí)行宏任務(wù)setTimout的回調(diào)函數(shù)

我是分隔符


文末思考題:


image.png

先別著急看答案


打印的順序是什么呢乘碑?挖息?

只要記住先把微任務(wù)先執(zhí)行完就清楚啦

答案:

  • 開始
  • fn1
  • ajaxfn
  • ajaxfn
  • 結(jié)束
  • ajaxpromise結(jié)束
  • ajaxpromise結(jié)束2
  • promise3
  • setTimeout
  • setTimeout2

ok,事件循環(huán)和事件隊(duì)列你是否搞清楚了呢?反正我目前來說是有點(diǎn)清晰了兽肤,還需要在工作當(dāng)中多去實(shí)踐和認(rèn)證套腹,如果文章中有不對的地方和描述不是很清晰的地方希望看到這篇文章的大佬幫忙指正,可以留言評論區(qū)喲~先謝各位有緣刷到此篇文章的大佬了资铡,感謝你們能看到這篇文章的結(jié)尾處电禀。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市笤休,隨后出現(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ī)與錄音蛇尚,去河邊找鬼芽唇。 笑死,一個(gè)胖子當(dāng)著我的面吹牛取劫,可吹牛的內(nèi)容都是我干的匆笤。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼谱邪,長吁一口氣:“原來是場噩夢啊……” “哼疚膊!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起虾标,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤寓盗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后璧函,有當(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
  • 正文 我和宋清朗相戀三年蘸吓,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了善炫。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,040評論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡库继,死狀恐怖箩艺,靈堂內(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. 我叫王不留,地道東北人腾夯。 一個(gè)月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓颊埃,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蝶俱。 傳聞我的和親對象是個(gè)殘疾皇子班利,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評論 2 355

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