JavaScript Event Loop相關原理解析

 更新時間:2020-06-14 00:00:56   作者:佚名   我要評論(0)

1.單線程模型
單線程模型指的是,JavaScript只能在一個線程上運行,也就是說只能同時指向一個任務,其他任務都必須在后面排隊等待。注意:雖然JavaScript只在一個線

1.單線程模型

單線程模型指的是,JavaScript只能在一個線程上運行,也就是說只能同時指向一個任務,其他任務都必須在后面排隊等待。注意:雖然JavaScript只在一個線程上運行,但并不代碼JavaScript引擎只有一個線程。事實上,JavaScript引擎有多個線程,單個腳本只能在一個線程上運行(主線程),其他線程都是在后臺配合。

JavaScript為什么要采用單線程,而不是多線程?

不想讓瀏覽器變得復雜(避免復雜性),因為多線程需要共享資源、且可能修改彼此運行的結果。

該模式會導致的問題?

如果單個任務耗時長,會拖延整個程序的執行,可能導致瀏覽器無響應(假死)

JavaScript是如何解決這個問題的?

因為單線程的原因,CPU很多時候都閑著的,并且因為IO操作(輸入輸出)很慢(比如Ajax操作從網絡讀取數據),這時CPU可以完全不管IO操作,掛起等待中的任務,先運行排在后面的任務。等到IO操作返回了結果,再回過頭,把掛起的任務繼續執行下去。這種機制就是JavaScript內部采用的“事件循環”機制(Event Loop)

2.同步任務和異步任務

程序里面所有的任務,可以分成兩類:同步任務(synchronous)和異步任務(asynchronous)

同步任務:沒有被引擎掛起、在主線程上排隊執行的任務。只有前一個任務執行完畢,才能執行后一個任務。

異步任務:被引擎放一邊、不進行主線程、而進入任務隊列的任務。只有引擎認為某個異步任務可以執行了(比如Ajax操作從服務器得到了結果),那么該任務(通過回調函數的形式)才能進入主線程執行。排在異步任務后面的代碼,不用等到異步任務結束就會馬上運行,也就是說,異步任務不具有“堵塞”效應

3.任務隊列和事件循環

JavaScript運行時,除了一個正在運行的主線程(又稱為“調用棧(call stack)”),引擎還提供了一個任務隊列(task queue),里面是各種需要處理當前程序處理的異步任務。(實際上,根據異步任務的類型,存在多個任務隊列,后面再詳講)

1.主線程會去執行所有的同步任務。

2.等到同步任務全部執行完,查看任務隊列中的異步任務,將滿足條件的重新進入主線程開始執行,這時候就變成同步任務。

3.等任務執行完,下一個異步任務再進入主線程開始執行。

4.引擎不停檢查(“事件循環”),一旦任務隊列清空,程序就結束執行。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

  • javascript事件循環event loop的簡單模型解釋與應用分析
  • 前端js中的事件循環eventloop機制詳解
  • Node.js Event Loop各階段講解
  • javascript中的event loop事件循環詳解
  • JavaScript中EventLoop介紹
  • Node.js事件循環(Event Loop)和線程池詳解
  • JavaScript運行機制之事件循環(Event Loop)詳解

相關文章

  • JavaScript Event Loop相關原理解析

    JavaScript Event Loop相關原理解析

    1.單線程模型 單線程模型指的是,JavaScript只能在一個線程上運行,也就是說只能同時指向一個任務,其他任務都必須在后面排隊等待。注意:雖然JavaScript只在一個線
    2020-06-14

最新評論

买宝宝用品赚钱吗 辽宁省快乐12选五开奖号码 北京pk拾手机app排行 佳人期货配资公司 东北期货配资网 双彩求开奖结果 急速赛车场 炒股知识 江苏快三官网在线购买 腾讯分分彩计划最准软件 福彩北京快中彩走势图 亚洲哪个国家赌博合法 华旭期货股票配资 排三和值连线走势图 双色球走势图500期图 一分钟一期的彩票骗局 广东好彩1开奖官网