真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

node中IO以及定時器優(yōu)先級的示例分析

這篇文章主要介紹node中IO以及定時器優(yōu)先級的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

烏蘇ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

事件循環(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í)行完后,才會進入到下一個循環(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

以上是“node中IO以及定時器優(yōu)先級的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


網(wǎng)站名稱:node中IO以及定時器優(yōu)先級的示例分析
文章位置:http://weahome.cn/article/jhoehd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部