91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

node中IO以及定時器優先級的示例分析

發布時間:2021-08-17 13:43:08 來源:億速云 閱讀:96 作者:小新 欄目:web開發

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

事件循環

node著名的基于eventloop 的單線程事件循環處理模型,高效的異步IO

異步API(定時器)

  • setTimeout 一次性定時器,執行一次,是把執行定時到到后面的隊列

  • setInterval 是把執行定時到到后面的隊列

setTimeout/setinterval 都會被插入到定時器觀察者內部的一個紅黑樹中,每次Tick執行是,從紅黑樹中迭代定時器對象,檢查超時時間,如果超過,形成事件,回調函數立即執行 時間復雜度是O(lg(n))
定時器實際上是不準確的,如果當前Tick阻塞執行很長時間,其實下次已經延誤了很長時間

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)

執行結果
sogubaby ~/Desktop/learn_node/manyprocess$node sync.js 
step one
setp two 25000500002539570000
settimeout2
timeInterval
timeInterval
timeInterval
timeInterval

會發現,當前循環已經阻塞了Tick的執行,所以定時器被延誤了
  • process.nextTick 會放到下次執行的Tick隊列中,是在當前執行完,下次遍歷前執行,時間復雜度是O(1),回調函數保存在數組中

  • setImmediate 在當前隊列立即執行,與process.nextTick 類似,也會延遲回調函數執行,回調函數保存在鏈表中

但是setImmediate的優先級會低于process.nextTick ,主要是因為事件循環對觀察者的檢查順序是有先后的,

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)

執行結果如下
sogubaby ~/Desktop/learn_node/manyprocess$node sync.js 
step one
setp two 2.500027500029909e+21
setInmediate

說明主線程會阻塞的,當前線程執行完后,才會進入到下一個循環

優先級

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)

執行結果
setp two 0
process.nextTick
setTimeout
setImmediate

以上是“node中IO以及定時器優先級的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

临城县| 思南县| 乌兰浩特市| 天长市| 铜川市| 潞西市| 汉源县| 长沙县| 敖汉旗| 仁寿县| 商都县| 浦县| 木里| 大悟县| 子长县| 南京市| 桂林市| 林芝县| 大同市| 闸北区| 仪征市| 通山县| 宜阳县| 稻城县| 柳州市| 盐亭县| 醴陵市| 长寿区| 荣成市| 延津县| 牡丹江市| 大冶市| 鹤壁市| 桐乡市| 吴桥县| 辽阳县| 八宿县| 于都县| 广西| 大田县| 那曲县|