首頁 >web前端 >js教程 >JS定時器和單線程非同步特性

JS定時器和單線程非同步特性

不言
不言原創
2018-07-07 10:05:001849瀏覽

這篇文章主要介紹了關於JS定時器和單線程異步特性,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

首先要說的是,定時器相關的方法都是屬於BOM方法,而定時器呢,它是用於在設定的時
間執行一段程式碼,或是在給定的時間間隔內重複該程式碼。具體函數:

setTimeout(callback, delay);//delay一定的时间后,执行回调函数只执行一次
setInterval(callback, delay);//每隔一段时间执行一次callback,反复执行
clearInterval(timer);//清除定时

計時器確實很好用,但是卻又不好用,為什麼這麼說呢?
我們知道JS是單線程的,既然是單線程那麼就很容易出現線程被堵塞的情況,要怎麼解決
呢? ——異步!
當然JS是單線程的它本身是不能異步的,但JS的宿主環境(比如瀏覽器,node)是多線程
的,宿主環境通過某種方式(比如:node的事件驅動)使得JS具備了異步的特性。
為什麼突然談起JS的單執行緒非同步呢?因為定時器事件會被JS非同步處理,什麼意思?
用程式碼來說:

var num = 1;
setTimeout(function() {
    num++;
    console.log(num);
}, 1000);
console.log(num); //结果并是不(2,1)而是(1,2)

為什麼會這樣?前面說了,JS會把定時器事件異步處理,也就是說它並不會等待定時器事件

#處理完成後再執行下面的程式碼,而是直接將計時器事件插入到事件佇列當中後,直接執行下面

的程式碼,當計時器事件執行完成後JS再反過頭來執行計時器事件的回呼部分程式碼,這就是非同步!

非同步可以有效的防止JS線程被堵塞,且會有很高的效率,能夠使JS在有限的資源下做更多的事

情,這一點是很了不起的。 (node中我們會大量接觸關於非同步的問題)

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

JS非同步程式設計之Promise、Generator、async/await

JS非同步程式設計的介紹

以上是JS定時器和單線程非同步特性的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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