亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript事件循環(huán)及宏任務(wù)微任務(wù)原理解析

 更新時(shí)間:2020年09月02日 11:51:50   作者:vickylinj  
這篇文章主要介紹了JavaScript事件循環(huán)及宏任務(wù)微任務(wù)原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

首先看一段代碼:

打印順序是什么?

正確答案:script start, script end, promise1, promise2, setTimeout

其中涉及到事件循環(huán)(event loop),宏任務(wù)(macrotask),微任務(wù)(microtask)

一、事件循環(huán) Event Loop

程序中設(shè)置兩個(gè)線程:一個(gè)負(fù)責(zé)程序本身的運(yùn)行,稱為"主線程";另一個(gè)負(fù)責(zé)主線程與其他進(jìn)程(主要是各種I/O操作)的通信,被稱為"Event Loop線程"(可以譯為"消息線程")。

所有任務(wù)可以分成兩種,一種是同步任務(wù)(synchronous),另一種是異步任務(wù)(asynchronous)。

同步任務(wù)指的是,在主線程上排隊(duì)執(zhí)行的任務(wù),只有前一個(gè)任務(wù)執(zhí)行完畢,才能執(zhí)行后一個(gè)任務(wù);

異步任務(wù)指的是,不進(jìn)入主線程、而進(jìn)入"任務(wù)隊(duì)列"(task queue)的任務(wù),只有"任務(wù)隊(duì)列"通知主線程,某個(gè)異步任務(wù)可以執(zhí)行了,該任務(wù)才會(huì)進(jìn)入主線程執(zhí)行。

一般而言,異步任務(wù)有以下三種類型:

  1、普通事件,如click、resize等

  2、資源加載,如load、error等

  3、定時(shí)器,包括setInterval、setTimeout等

事件循環(huán)具體過程就是:

  • 同步任務(wù)進(jìn)入主線程,異步任務(wù)進(jìn)入Event Table并注冊(cè)函數(shù)。
  • 當(dāng)異步任務(wù)完成時(shí),Event Table會(huì)將這個(gè)函數(shù)移入Event Queue。
  • 主線程內(nèi)的任務(wù)執(zhí)行完畢執(zhí)行棧為空,會(huì)去Event Queue讀取對(duì)應(yīng)的函數(shù),進(jìn)入主線程執(zhí)行。
  • 上述過程會(huì)不斷重復(fù),也就是常說的Event Loop(事件循環(huán))。

二、宏任務(wù)與微任務(wù)

在JavaScript中,任務(wù)被分為兩種,一種宏任務(wù)(MacroTask),一種叫微任務(wù)(MicroTask)。

2.1MacroTask(宏任務(wù))

宿主環(huán)境提供的(瀏覽器和node)

script全部代碼、setTimeout、setInterval。

瀏覽器為了能夠使得JS內(nèi)部task與DOM任務(wù)能夠有序的執(zhí)行,會(huì)在一個(gè)task執(zhí)行結(jié)束后,在下一個(gè) task 執(zhí)行開始前,對(duì)頁面進(jìn)行重新渲染 (task->渲染->task->...)

2.2MicroTask(微任務(wù))

語言標(biāo)準(zhǔn)提供的

Promise、await

async函數(shù)表示函數(shù)里面可能會(huì)有異步方法,await后面跟一個(gè)表達(dá)式,async方法執(zhí)行時(shí),遇到await會(huì)立即執(zhí)行表達(dá)式,然后把a(bǔ)wait表達(dá)式后面的代碼放到微任務(wù)隊(duì)列里,讓出執(zhí)行棧讓同步代碼先執(zhí)行

async function foo() {
  var a = await new Promise((resolve) => {
    setTimeout(() => {
      resolve(1);
    }, 2000);
  });
  console.log(a); // 第2秒時(shí)輸出: 1
}
foo();

2.3宏任務(wù)與微任務(wù)執(zhí)行順序:

  • 執(zhí)行棧在執(zhí)行完同步任務(wù)后,查看執(zhí)行棧是否為空,如果執(zhí)行棧為空,就會(huì)去檢查微任務(wù)隊(duì)列是否為空,如果為空的話,就執(zhí)行宏任務(wù),否則就一次性執(zhí)行完所有微任務(wù)。
  • 每次單個(gè)宏任務(wù)執(zhí)行完畢后,檢查微任務(wù)隊(duì)列是否為空,如果不為空的話,會(huì)按照先入先出的規(guī)則全部執(zhí)行完微任務(wù)后,設(shè)置微任務(wù)隊(duì)列為null,然后再執(zhí)行宏任務(wù),如此循環(huán)。

總結(jié):同步—>微任務(wù)—>宏任務(wù)

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

相關(guān)文章

  • Bootstrap開發(fā)中Tab標(biāo)簽頁切換圖表顯示問題的解決方法

    Bootstrap開發(fā)中Tab標(biāo)簽頁切換圖表顯示問題的解決方法

    這篇文章主要給大家介紹了關(guān)于Bootstrap開發(fā)中Tab標(biāo)簽頁切換圖表顯示問題的解決方法,文中通過圖文以及示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • JavaScript重復(fù)元素處理方法分析【統(tǒng)計(jì)個(gè)數(shù)、計(jì)算、去重復(fù)等】

    JavaScript重復(fù)元素處理方法分析【統(tǒng)計(jì)個(gè)數(shù)、計(jì)算、去重復(fù)等】

    這篇文章主要介紹了JavaScript重復(fù)元素處理方法,結(jié)合實(shí)例形式分析了javascript針對(duì)字符串、數(shù)組中重復(fù)元素的個(gè)數(shù)統(tǒng)計(jì),計(jì)算及去重復(fù)等相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • JS中Symbol類型的介紹與基本用法

    JS中Symbol類型的介紹與基本用法

    Symbol是一種特殊的、不可變的數(shù)據(jù)類型,可以作為對(duì)象屬性的標(biāo)識(shí)符使用,表示獨(dú)一無二的值,這篇文章主要給大家介紹了關(guān)于JS中Symbol類型的介紹與基本用法的相關(guān)資料,需要的朋友可以參考下
    2024-04-04
  • Openlayers實(shí)現(xiàn)地圖全屏顯示

    Openlayers實(shí)現(xiàn)地圖全屏顯示

    這篇文章主要為大家詳細(xì)介紹了Openlayers實(shí)現(xiàn)地圖全屏顯示,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • 對(duì)象題目的一個(gè)坑 理解Javascript對(duì)象

    對(duì)象題目的一個(gè)坑 理解Javascript對(duì)象

    這篇文章主要介紹了Javascript對(duì)象,特別為大家分享了對(duì)象題目的一個(gè)坑,提供了解題思路,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JavaScript模塊化之使用requireJS按需加載

    JavaScript模塊化之使用requireJS按需加載

    RequireJS 可以幫助用戶異步按需的加載 JavaScript 代碼,并解決 JavaScript 模塊間的依賴關(guān)系,提升了前端代碼的整體質(zhì)量和性能
    2017-04-04
  • axios請(qǐng)求參數(shù)的三種方式示例詳解

    axios請(qǐng)求參數(shù)的三種方式示例詳解

    這篇文章主要介紹了axios請(qǐng)求參數(shù)的三種方式,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • JS解決url傳值出現(xiàn)中文亂碼的另類辦法

    JS解決url傳值出現(xiàn)中文亂碼的另類辦法

    為什么用表單的方式就可以傳遞中文,而URL的方式就不行了呢?非得用URL傳值的方式才能解決問題嗎?這里我想到了動(dòng)態(tài)表單,何不用它來解決呢
    2013-04-04
  • javascript內(nèi)存分配原理實(shí)例分析

    javascript內(nèi)存分配原理實(shí)例分析

    這篇文章主要介紹了javascript內(nèi)存分配原理,結(jié)合實(shí)例形式分析了javascript原始值和引用值內(nèi)存分配的原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-04-04
  • bootstrap中的 form表單屬性role=

    bootstrap中的 form表單屬性role="form"的作用詳解

    這篇文章主要介紹了bootstrap中的 form表單屬性role="form"的作用詳解,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-01-01

最新評(píng)論