02 瀏覽器和Node中eventloop的區(qū)別(js執(zhí)行機(jī)制)

瀏覽器和Node中eventloop的區(qū)別(js執(zhí)行機(jī)制)

一、瀏覽器端的eventloop

1)1個(gè)函數(shù)執(zhí)行棧逻锐,1個(gè)微任務(wù)隊(duì)列摔刁,1個(gè)時(shí)間隊(duì)列
2)宏任務(wù)與微任務(wù)

  1. 宏任務(wù): macrotask 也叫tasks,異步回調(diào)會(huì)進(jìn)入tasks个少,其包含:
  1. setTimeout
  2. setInterval
  3. setImmediate(Node)
  4. requestAnimationFrame (瀏覽器)
  5. I/O
  6. UI rendering
  1. 微任務(wù): microtask蒙揣, 也叫jobs靶溜,另一些異步任務(wù)microtask,其包含:
  1. process.nextTick(Node)
  2. promise.then()
  3. Object.observe
  4. Mutation.observer

執(zhí)行順序:執(zhí)行棧 > 微任務(wù) > 宏任務(wù)

二懒震、 NodeJs中的eventloop

執(zhí)行機(jī)制:

  1. times(計(jì)時(shí)期)
  2. I/O callbacks處理流罩息、網(wǎng)絡(luò)、tcp錯(cuò)誤callback
  3. idle个扰、prepare node內(nèi)部使用
  4. poll輪詢瓷炮,執(zhí)行poll中的I/O隊(duì)列,檢查定時(shí)器是否到時(shí)
  5. check(檢查)存放setImmediate回調(diào)
  6. close callbacks關(guān)閉回調(diào) socket.on('close')

執(zhí)行過(guò)程:

  1. 執(zhí)行js中的同步代碼
  2. 執(zhí)行microtask微任務(wù)递宅,先執(zhí)行NextTickQueue中的所有任務(wù)娘香,在執(zhí)行Other Microtask Queue中的所有任務(wù)。
  3. 開(kāi)始執(zhí)行macrotask宏任務(wù)恐锣,共6個(gè)階段茅主,從第1個(gè)階段開(kāi)始舞痰,執(zhí)行相應(yīng)的每個(gè)階段macrotask中的所有任務(wù)土榴,注意:這里是所有每個(gè)階段宏任務(wù)隊(duì)列的所有任務(wù),在瀏覽器中的eventloop只取宏任務(wù)中的第一個(gè)任務(wù)出來(lái)執(zhí)行响牛,每一個(gè)階段的macrotask任務(wù)執(zhí)行完畢后玷禽,開(kāi)始執(zhí)行微任務(wù),也就是步驟2
  4. Times queue -> 步驟2 -> I/O queue -> 步驟2 -> check queue -> 步驟2 -> close callback queue -> 步驟2 -> timers queue
  5. 這就是node的eventloop的簡(jiǎn)化版

三呀打、瀏覽器和Node中的eventloop的區(qū)別

  1. 實(shí)現(xiàn)機(jī)制不同
  2. nodejs可以理解成4個(gè)宏任務(wù)和2個(gè)微任務(wù)隊(duì)列矢赁,但執(zhí)行宏任務(wù)時(shí),有6個(gè)步驟
  3. Nodejs中贬丛,先執(zhí)行全局的js代碼撩银,執(zhí)行完同步代碼調(diào)用棧,清空后豺憔,先從微任務(wù)隊(duì)列NextTick queue中依次取出所有的任務(wù)额获,放入調(diào)用棧執(zhí)行;再?gòu)奈⑷蝿?wù)隊(duì)列中的other microtask queue中依次取出所有任務(wù)放入調(diào)用棧執(zhí)行恭应。然后開(kāi)始宏任務(wù)的6個(gè)階段抄邀,每個(gè)階段都將該宏任務(wù)隊(duì)列中的所有任務(wù)都取出來(lái)執(zhí)行,每個(gè)宏任務(wù)階段執(zhí)行完畢后昼榛,開(kāi)始執(zhí)行微任務(wù)境肾,在開(kāi)始執(zhí)行下一階段的宏任務(wù),以此構(gòu)建事件循環(huán)。
  4. Microtask包括:setTimeout\setInterval\setImmediate\requestAnimation\I/O\UI rendering
  5. Microtask包括:process.nextTick(Node)\promise.then()\Object.observe\Mutation.observer


注意:new promise()構(gòu)造函數(shù)里面的是同步代碼奥喻,非微任務(wù)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末偶宫,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子环鲤,更是在濱河造成了極大的恐慌读宙,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件楔绞,死亡現(xiàn)場(chǎng)離奇詭異结闸,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)酒朵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門桦锄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蔫耽,你說(shuō)我怎么就攤上這事结耀。” “怎么了匙铡?”我有些...
    開(kāi)封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵图甜,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我鳖眼,道長(zhǎng)黑毅,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任钦讳,我火速辦了婚禮矿瘦,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘愿卒。我一直安慰自己缚去,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布琼开。 她就那樣靜靜地躺著易结,像睡著了一般。 火紅的嫁衣襯著肌膚如雪柜候。 梳的紋絲不亂的頭發(fā)上搞动,一...
    開(kāi)封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音改橘,去河邊找鬼滋尉。 笑死,一個(gè)胖子當(dāng)著我的面吹牛飞主,可吹牛的內(nèi)容都是我干的狮惜。 我是一名探鬼主播高诺,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼碾篡!你這毒婦竟也來(lái)了虱而?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤开泽,失蹤者是張志新(化名)和其女友劉穎牡拇,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體穆律,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡惠呼,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了峦耘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片剔蹋。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖辅髓,靈堂內(nèi)的尸體忽然破棺而出泣崩,到底是詐尸還是另有隱情,我是刑警寧澤洛口,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布矫付,位于F島的核電站,受9級(jí)特大地震影響第焰,放射性物質(zhì)發(fā)生泄漏买优。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一樟遣、第九天 我趴在偏房一處隱蔽的房頂上張望而叼。 院中可真熱鬧,春花似錦豹悬、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至娇钱,卻和暖如春伤柄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背文搂。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工适刀, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人煤蹭。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓笔喉,卻偏偏與公主長(zhǎng)得像取视,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子常挚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355

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