簡單談?wù)凧avaScript的同步與異步
1.手繪一張圖說明。
2.為什么JavaScript是單線程(這里引用阮一峰老師的話)
JavaScript的單線程,與它的用途有關(guān)。
作為瀏覽器腳本語言,JavaScript的主要用途是與用戶互動,以及操作DOM。
這決定了它只能是單線程,否則會帶來很復(fù)雜的同步問題。
比如,假定JavaScript同時有兩個線程,一個線程在某個DOM節(jié)點上添加內(nèi)容,另一個線程刪除了這個節(jié)點,這時瀏覽器應(yīng)該以哪個線程為準?
所以,為了避免復(fù)雜性,從一誕生,JavaScript就是單線程,這已經(jīng)成了這門語言的核心特征,將來也不會改變。
為了利用多核CPU的計算能力,HTML5提出Web Worker標準,允許JavaScript腳本創(chuàng)建多個線程,但是子線程完全受主線程控制,且不得操作DOM。
所以,這個新標準并沒有改變JavaScript單線程的本質(zhì)。
傳送門:JavaScript運行機制之事件循環(huán)(Event Loop)詳解
3.JavaScript的異步體現(xiàn)在哪
如一開始的圖,個人認為左邊主線程就是同步,左邊事件隊列(消息隊列)就是異步。
當(dāng)然JavaScript中的異步有很多:
Ajax(XMLHttpRequest) Image Tag,Script Tag,iframe(原理類似) setTimeout/setInterval CSS3 Transition/Animation postMessage Web Workers Web Sockets and more…
相關(guān)文章
使用typescript類型實現(xiàn)ThreeSum
這篇文章主要介紹了使用typescript類型實現(xiàn)ThreeSum,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以一下,希望對你學(xué)習(xí)又是幫助2022-08-08Parcel.js + Vue 2.x 極速零配置打包體驗教程
這篇文章主要介紹了Parcel.js + Vue 2.x 極速零配置打包體驗 的相關(guān)資料,需要的朋友可以參考下2017-12-12詳解JS中的compose函數(shù)和pipe函數(shù)用法
這篇文章主要介紹了JS中的compose函數(shù)和pipe函數(shù)用法,想深入了解Javascript的同學(xué),可以參考下2021-04-04js+canvas實現(xiàn)繪制正方形并插入文字效果(居中顯示)
canvas是一個可以讓我們使用腳本繪圖的標簽,它提供了一系列完整的屬性和方法,下面這篇文章主要給大家介紹了js+canvas實現(xiàn)繪制正方形并插入文字居中顯示效果的相關(guān)資料,需要的朋友可以參考下2023-11-11javascript中Date對象應(yīng)用之簡易日歷實現(xiàn)
這篇文章主要為大家詳細介紹了javascript中Date對象應(yīng)用之簡易日歷實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-07-07