同步和異步

區別: 會不會阻塞當前程序運行ajax

何時須要異步:網絡

(1)須要等待的時候,等待過程不能卡在這吧異步

(2)等待過程不像alert同樣阻塞程序運行函數

(3)等待的狀況都要異步blog

使用異步的場景:隊列

(1)定時任務,setTimeout,setInterval事件

(2)網絡請求: ajax請求,動態<img>加載同步

(3)事件綁定,點擊等交互事件console

 

 

 

幾個問題:定時任務

1. 同步和異步的區別是什麼

   同步阻塞代碼運行,alert是同步,setTimeout是異步

2. 一個setTimeout的例子

JS引擎掃描一遍,將事件按順序加入任務隊列,而後執行,此時注意setTimeout中的函數是在定時完成後纔會加入隊列

因此剛開始隊列中 有 console.log(1),setTimeout(fn1,0),console.log(3),setTimeout(fn2,1000),console.log(5)

輸出1,執行setTimeout後,再過0ms將fn1加入到任務隊列尾部,此時隊列中有console.log(3),setTimeout(fn2,1000),console.log(5),fn1

再輸出3,執行setTimeout,過了1000ms將fn2加到任務隊列尾部,輸出5,再執行fn1,fn2

事件執行過程當中的事件循環,JS引擎有個運行棧,不斷從任務隊列裏讀取任務運行,運行棧爲空,便檢查任務隊列,一直加入,循環往復,直至任務隊列也爲空

相關文章
相關標籤/搜索