首頁 >web前端 >js教程 >javascript實作執行緒以及事件循環詳解

javascript實作執行緒以及事件循環詳解

韦小宝
韦小宝原創
2018-03-14 16:08:191334瀏覽

 這篇文章講述了javascript實現線程以及事件循環,大家對javascript實現線程以及事件循環不了解的話或者對javascript實現線程以及事件循環感興趣的話那麼我們就一起來看看這篇文章吧,好了廢話少說進入正題吧

1.為什麼說JavaScript是單執行緒的?

瀏覽器渲染頁面過程中涉及到的幾個執行緒有:JavaScript執行緒,負責執行js程式碼,UI執行緒,負責UI展示,JavaScript事件循環執行緒,管

理JavaScript事件,其中JavaScript執行緒與UI執行緒是互斥的.如果說JavaScript是多執行緒的話,那麼多個JavaScript執行緒在操作同一

個dom的時候,例如分別把一個按鈕變成紅色和黃色,這時候UI執行緒就懵逼了,應該聽誰的? JavaScript中為了避免這種出現這種情況,這些

線程必須分開執行,所以JavaScript是單線程的,這已經成了這門語言的核心特徵,將來也不會改變。

2.JavaScript任務佇列結構與事件循環

單執行緒就意味著,所有任務需要排隊,前一個任務結束,才會執行後一個任務。如果前一個任務耗時很長,後一個任務就不得不

一直等著。

JavaScript中執行任務是依照佇列資料結構形式來執行的,如下圖:


JavaScript中的任務:

1.同步任務:for迴圈,求和,js賦值,js運算等

#2.非同步任務:dom事件,bom的api處理 ajax

所謂"回呼函數"(callback),就是那些會被主執行緒掛起來的程式碼。非同步任務必須指定回呼函數,當主執行緒開始執行非同步任務,

就是執行對應的回呼函數。

循環機制:

JavaScript主執行緒直接執行同步任務,非同步任務先執行一部分,然後退出主執行緒執行,然後等非同步任務再準備好之後再交給主執行緒執行,

總之,JavaScript的程式碼是佇列的形式一個個進行執行的,同一時間只能執行一段程式碼.

以上就是這篇文章的所有內容,大家要是還不太了解的話,可以嘗試著去寫點事件循環等這樣就很容易掌握了哦!

相關推薦:

#細說JavaScript事件循環機制-第一講

#細說JavaScript事件循環機制-第二講

#javascript事件循環機制實例詳解

#

以上是javascript實作執行緒以及事件循環詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn