記錄--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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...