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
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
相关文章
nodejs 使用http进行post或get请求的实例(携带cookie)
今天小编就为大家分享一篇nodejs 使用http进行post或get请求的实例(携带cookie),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-01-01nodejs require js文件入口,在package.json中指定默认入口main方法
今天小编就为大家分享一篇nodejs require js文件入口,在package.json中指定默认入口main方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-10-10nodejs处理图片的几种方法总结(使用sharp、jimp及webconvert)
这篇文章主要给大家介绍了关于nodejs处理图片的几种方法,文中介绍的方法分别是sharp、jimp及webconvert,在开发过程中我们有时候需要对图片进行处理,给一个图片添加水印、多个图片合成为一图片等操作,需要的朋友可以参考下2023-12-12
最新评论