記錄--Event Loop事件迴圈、微任務、巨集任務

来源:https://www.cnblogs.com/smileZAZ/archive/2022/06/30/16427104.html
-Advertisement-
Play Games

這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 前言 JS是一門單線程語言,單線程就意味著,所有的任務需要排隊,前一個任務結束,才會執行下一個任務。這樣所導致的問題是:如果JS執行的時間過長,這樣就會造成頁面的渲染不連貫,導致頁面渲染載入阻塞的覺。為瞭解決這個問題,JS中出現了同步和異 ...


這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助

前言

JS是一門單線程語言,單線程就意味著,所有的任務需要排隊,前一個任務結束,才會執行下一個任務。這樣所導致的問題是:如果JS執行的時間過長,這樣就會造成頁面的渲染不連貫,導致頁面渲染載入阻塞的覺。為瞭解決這個問題,JS中出現了同步和非同步。他們的本質區別是:一條流水線上各個流程的執行順序不同。在講JS任務執行機制前,先要瞭解一下什麼是同步任務與非同步任務。

同步任務:即主線程上的任務,按照順序由上⾄下依次執⾏,當前⼀個任務執⾏完畢後,才能執⾏下⼀個任務。

非同步任務:不進⼊主線程,⽽是進⼊任務隊列的任務,執行完畢之後會產生一個回調函數,並且通知主線程。當主線程上的任務執行完後,就會調取最早通知自己的回調函數,使其進入主線程中執行。

1. 事件迴圈Event Loop概念介紹

  • 事件迴圈Event Loop又叫事件隊列,兩者是一個概念

事件迴圈指的是js代碼所在運行環境(瀏覽器、nodejs)編譯器的一種解析執行規則。事件迴圈不屬於js代碼本身的範疇,而是屬於js編譯器的範疇,在js中討論事件迴圈是沒有意義的。換句話說,js代碼可以理解為是一個人在公司中具體做的事情, 而 事件迴圈 相當於是公司的一種規章制度。 兩者不是一個層面的概念。

2. 微任務、巨集任務概念介紹

  1. 微任務與巨集任務就屬於js代碼的範疇
  2. js代碼主要分為兩大類: 同步代碼、非同步代碼
  3. 非同步代碼又分為:微任務與巨集任務

3. 事件迴圈Event Loop執行機制

  • 1.進入到script標簽,就進入到了第一次事件迴圈.

  • 2.遇到同步代碼,立即執行

  • 3.遇到巨集任務,放入到巨集任務隊列里.

  • 4.遇到微任務,放入到微任務隊列里.

  • 5.執行完所有同步代碼

  • 6.執行微任務代碼

  • 7.微任務代碼執行完畢,本次隊列清空

  • 尋找下一個巨集任務,重覆步驟1

    • 以此反覆直到清空所以巨集任務,這種不斷重覆的執行機制,就叫做事件迴圈

畫了一張圖來描述事件迴圈

4.易錯點

(1). promise本身是一個同步的代碼(只是容器),只有它後面調用的then()方法裡面的回調才是微任務

 (2). await右邊的表達式還是會立即執行,表達式之後的代碼才是微任務, await微任務可以轉換成等價的promise微任務分析

 (3). script標簽本身是一個巨集任務, 當頁面出現多個script標簽的時候,瀏覽器會把script標簽作為巨集任務來解析

看到這裡,對事件迴圈應該有所瞭解了,給大家看幾道面試題。

一.

 

1.先執行主線程上的log(1)

2.當有兩個await時,只有第一個await右邊的代碼會立即執行log(4),後面的幾行代碼都會放入微任務隊列中。

3.執行主線程上的log(6)

4.執行第4行至第6行的微任務

二.

1.先執行主線程上的1,5,7

2.主線程的同步任務執行完畢後,會先執行微任務。執行Promise的then方法里的代碼,列印6

3.微任務執行完畢後,最後執行定時器里的巨集任務,列印2,3,4

三.

1.先執行主線程上的同步代碼,列印1

2.執行第9行的函數,進⼊async1內部,async1其實是聲明瞭⼀個promise,promise是同步代碼,會順序執⾏列印async2函數里的4 ,只有.then⾥⾯的代碼會加⼊微任務隊列⾥,這⾥相當於執⾏了async2()之後,再將後面的代碼加⼊⼀個微任務隊列中。

3.回主線程中,遇到setTimeout(),加⼊到巨集任務隊列

4.主線程繼續往後執⾏,前⾯說過,promise是同步代碼,.then後⾯的回調會加⼊微任務隊列,所以會列印13⾏的7

5.主線程執⾏完成,開始執⾏微任務隊列內的任務,遵循先進先出的原則,列印第四⾏的2。然後接著執行第5行第二個awaite右邊的代碼,列印5。第6行這個時候就被加入微任務隊列。

6.接著會執行第二個微任務,也就是16行代碼,列印8。第17行的then這個時候也會加入微任務隊列。再依次執行第6行和第17行的兩個微任務,列印3和9

7.微任務執⾏結束,開始執⾏巨集任務setTimeout,列印11⾏的6.

總結

  1. 所有同步任務都在主線程上執行,形成一個執行棧(call stack)。
  2. 遇到非同步任務, 進入非同步處理模塊並註冊回調函數; 等到指定的事件完成(如ajax請求響應返回, setTimeout延遲到指定時間)時,非同步處理模塊會將這個回調函數移入非同步任務隊列。
  3. 當棧中的代碼執行完畢,執行棧中的任務為空時,主線程會先檢查微任務隊列中是否有任務,如果有,就將微任務隊列中的所有任務依次執行,直到微任務隊列為空; 之後再檢查巨集任務隊列中是否有任務,如果有,則取出第一個巨集任務加入到執行棧中,之後再清空執行棧,檢查微任務,以此迴圈,直到全部的任務都執行完成。

本文轉載於:

https://juejin.cn/post/7108751200262029319

如果對您有所幫助,歡迎您點個關註,我會定時更新技術文檔,大家一起討論學習,一起進步。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文鏈接:基於開源流批一體數據同步引擎ChunJun數據還原—DDL解析模塊的實戰分享 課件獲取:關註公眾號** “數棧研習社”,後臺私信 “ChunJun”**獲得直播課件 視頻回放:點擊這裡 ChunJun開源項目地址:github 丨 gitee 喜歡我們的項目給我們點個 STAR!STAR! ...
  • 案例來源: https://github.com/apache/flink-training/blob/release-1.14/README_zh.md 案例背景 計程車車程(taxi ride)事件結構 1.每次車程都由兩個事件表示:行程開始(trip start)和行程結束(trip end) ...
  • 前言:如題。直接上手擼,附帶各種截圖,就不做介紹了。 1、influxDB的官網下載地址 https://portal.influxdata.com/downloads/ 打開以後,如下圖所示,可以選擇版本號,以及平臺。此處咱們選擇windows平臺。不過此處沒有實際的可以下載的地方,著實比較過分, ...
  • 案例來源於 https://nightlies.apache.org/flink/flink-docs-release-1.14/docs/try-flink/datastream/ 案例背景 在當今數字時代,信用卡欺詐行為越來越被重視。 罪犯可以通過詐騙或者入侵安全級別較低系統來盜竊信用卡卡號。 ...
  • 2022年6月28日,HDD·HMS Core.Sparkle影音娛樂沙龍線上上與開發者們見面。HMS Core音頻編輯服務(Audio Editor Kit)專家為大家詳細分享了基於分離的3D音樂創作技術,引起了行業及音樂愛好者的關註。 音頻3D化是音頻發展的重要方向,但當前從源頭製作3D音頻成本 ...
  • 華為帳號是打開華為生態服務的一把鑰匙,只需一個華為帳號,即可在華為全場景設備上使用華為應用市場、華為音樂、華為雲空間、華為錢包等眾多優質的華為應用服務。同時,華為帳號綁定的所有會員權益、購買記錄、收藏/喜歡等數據,也會在不同設備間一鍵同步,輕鬆實現自由切換。 登錄華為帳號後,您可以在多台設備上,快捷 ...
  • Javascript趣味程式從需求到實現-體重測量器 Version 0.0.1 一、需求梳理 二、分析結果: 1、需要提供輸入身高、體重、以及選擇性別的HTML組件,如input、select 2、需要對信息進行驗證,專門的工具類完成這個職責如 “BmiUtils” 3、無效的信息需要提示 4、與 ...
  • 一、效果圖 二、實現邏輯 將需要動態添加的表單項項的綁定值存為一個數組 以迴圈的方式展示form表單 點擊`+`按鈕觸發事件,向數組中新加一個item 點擊`-`按鈕觸發事件,根據迴圈的得到的index來刪除數組中相對應位置的item 三、代碼實現 <template> <div> <el-butt ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...