欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

node中IO以及定时器优先级详解

程序员文章站 2022-03-20 14:42:28
事件循环 node著名的基于eventloop 的单线程事件循环处理模型,高效的异步io 异步api(定时器) settimeout 一次性定时器...

事件循环

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。