node中IO以及定時器優(yōu)先級詳解
事件循環(huán)
node著名的基于eventloop 的單線程事件循環(huán)處理模型,高效的異步IO
異步API(定時器)
- setTimeout 一次性定時器,執(zhí)行一次,是把執(zhí)行定時到到后面的隊列
- setInterval 是把執(zhí)行定時到到后面的隊列
setTimeout/setinterval 都會被插入到定時器觀察者內(nèi)部的一個紅黑樹中,每次Tick執(zhí)行是,從紅黑樹中迭代定時器對象,檢查超時時間,如果超過,形成事件,回調(diào)函數(shù)立即執(zhí)行 時間復(fù)雜度是O(lg(n))
定時器實際上是不準(zhǔn)確的,如果當(dāng)前Tick阻塞執(zhí)行很長時間,其實下次已經(jīng)延誤了很長時間
console.log("step one") setTimeout(function(){ console.log("settimeout2") },0) setInterval(function(){ console.log("timeInterval") },1000) let sum=0; for(let i=0;i<=100000;i++){ for(let j=0;j<=100000;j++){ sum+=i*j } } console.log("setp two",sum) 執(zhí)行結(jié)果 sogubaby ~/Desktop/learn_node/manyprocess$node sync.js step one setp two 25000500002539570000 settimeout2 timeInterval timeInterval timeInterval timeInterval 會發(fā)現(xiàn),當(dāng)前循環(huán)已經(jīng)阻塞了Tick的執(zhí)行,所以定時器被延誤了
- process.nextTick 會放到下次執(zhí)行的Tick隊列中,是在當(dāng)前執(zhí)行完,下次遍歷前執(zhí)行,時間復(fù)雜度是O(1),回調(diào)函數(shù)保存在數(shù)組中
- setImmediate 在當(dāng)前隊列立即執(zhí)行,與process.nextTick 類似,也會延遲回調(diào)函數(shù)執(zhí)行,回調(diào)函數(shù)保存在鏈表中
但是setImmediate的優(yōu)先級會低于process.nextTick ,主要是因為事件循環(huán)對觀察者的檢查順序是有先后的,
process.nextTick 屬于idle觀察者 setImmediate屬于check觀察者
idle> I/o> check
console.log("step one") setImmediate(function(){ console.log("setInmediate") }) let sum=0; for(let i=0;i<=1000000;i++){ for(let j=0;j<=100000;j++){ sum+=i*j } } console.log("setp two",sum) 執(zhí)行結(jié)果如下 sogubaby ~/Desktop/learn_node/manyprocess$node sync.js step one setp two 2.500027500029909e+21 setInmediate 說明主線程會阻塞的,當(dāng)前線程執(zhí)行完后,才會進(jìn)入到下一個循環(huán)
優(yōu)先級
process.nextTick(function(){ console.log("process.nextTick") }) setImmediate(function(){ console.log("setImmediate") }) setTimeout(function(){ console.log("setTimeout") },0) let sum=0; console.log("setp two",sum) 執(zhí)行結(jié)果 setp two 0 process.nextTick setTimeout setImmediate
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類
這篇文章主要介紹了詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04nodejs 使用http進(jìn)行post或get請求的實例(攜帶cookie)
今天小編就為大家分享一篇nodejs 使用http進(jìn)行post或get請求的實例(攜帶cookie),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01nodejs基于express實現(xiàn)文件上傳的方法
這篇文章主要介紹了nodejs基于express實現(xiàn)文件上傳的方法,結(jié)合實例形式分析了nodejs基于express框架實現(xiàn)文件上傳功能的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2018-03-03nodejs require js文件入口,在package.json中指定默認(rèn)入口main方法
今天小編就為大家分享一篇nodejs require js文件入口,在package.json中指定默認(rèn)入口main方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10NodeJs crypto加密制作token的實現(xiàn)代碼
這篇文章主要介紹了NodeJs crypto加密制作token的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11nodejs處理圖片的幾種方法總結(jié)(使用sharp、jimp及webconvert)
這篇文章主要給大家介紹了關(guān)于nodejs處理圖片的幾種方法,文中介紹的方法分別是sharp、jimp及webconvert,在開發(fā)過程中我們有時候需要對圖片進(jìn)行處理,給一個圖片添加水印、多個圖片合成為一圖片等操作,需要的朋友可以參考下2023-12-12