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


Posted in Javascript onMay 10, 2019

事件循环

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

总结

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

Javascript 相关文章推荐
繁简字转换功能
Jul 19 Javascript
javascript算法题 求任意一个1-9位不重复的N位数在该组合中的大小排列序号
Jul 21 Javascript
用按钮控制iframe显示的网页实现方法
Feb 04 Javascript
基于JavaScript实现网页倒计时自动跳转代码
Dec 28 Javascript
javascript断点调试心得分享
Apr 23 Javascript
JS获取checkbox的个数简单实例
Aug 19 Javascript
jQuery Validate表单验证插件的基本使用方法及功能拓展
Jan 04 Javascript
Vue 2.5.2下axios + express 本地请求404的解决方法
Feb 21 Javascript
全面解析vue router 基本使用(动态路由,嵌套路由)
Sep 02 Javascript
vue计算属性无法监听到数组内部变化的解决方案
Nov 06 Javascript
vue+webpack dev本地调试全局样式引用失效的解决方案
Nov 12 Javascript
vue打包通过image-webpack-loader插件对图片压缩优化操作
Nov 12 Javascript
使用Node.js写一个代码生成器的方法步骤
May 10 #Javascript
Easyui 去除jquery-easui tab页div自带滚动条的方法
May 10 #jQuery
使用vue脚手架(vue-cli)搭建一个项目详解
May 09 #Javascript
Node.js实现用户评论社区功能(体验前后端开发的乐趣)
May 09 #Javascript
微信小程序中显示倒计时代码实例
May 09 #Javascript
微信小程序日历弹窗选择器代码实例
May 09 #Javascript
vue2 v-model/v-text 中使用过滤器的方法示例
May 09 #Javascript
You might like
PHP学习 运算符与运算符优先级
2008/06/15 PHP
php中关于普通表单多文件上传的处理方法
2011/03/25 PHP
PHP include_path设置技巧分享
2011/07/03 PHP
thinkphp3查询mssql数据库乱码解决方法分享
2014/02/11 PHP
php实现在服务器上创建目录的方法
2015/03/16 PHP
Laravel 5框架学习之向视图传送数据(进阶篇)
2015/04/08 PHP
PHP实现的日历功能示例
2018/09/01 PHP
权威JavaScript 中的内存泄露模式
2007/08/13 Javascript
jQuery动态改变图片显示大小(修改版)的实现思路及代码
2013/12/24 Javascript
JS+CSS实现感应鼠标渐变显示DIV层的方法
2015/02/20 Javascript
jquery获取及设置outerhtml的方法
2015/03/09 Javascript
jquery利用命名空间移除绑定事件的方法
2015/03/11 Javascript
jQuery采用连缀写法实现的折叠菜单效果
2015/09/18 Javascript
jQuery插件支持同一页面被多次调用
2016/02/14 Javascript
用nodejs的实现原理和搭建服务器(动态)
2016/08/10 NodeJs
浅谈在js传递参数中含加号(+)的处理方式
2016/10/11 Javascript
jQuery实现单击按钮遮罩弹出对话框效果(2)
2017/02/20 Javascript
Angular实现一个简单的多选复选框的弹出框指令实例
2017/04/25 Javascript
小发现之浅谈location.search与location.hash的问题
2017/06/23 Javascript
Vue 电商后台管理项目阶段性总结(推荐)
2020/08/22 Javascript
在win和Linux系统中python命令行运行的不同
2016/07/03 Python
Python2随机数列生成器简单实例
2017/09/04 Python
python实现在遍历列表时,直接对dict元素增加字段的方法
2019/01/15 Python
Python实现AI自动抠图实例解析
2020/03/05 Python
Python如何操作office实现自动化及win32com.client的运用
2020/04/01 Python
详解HTML5中CSS外观属性
2020/09/10 HTML / CSS
现金会计岗位职责
2013/12/05 职场文书
消防安全管理制度
2014/02/01 职场文书
读书活动总结
2014/04/28 职场文书
幼儿教师求职信
2014/05/24 职场文书
2014年辅导员工作总结
2014/11/18 职场文书
幼儿学前班评语
2014/12/29 职场文书
民事诉讼代理词
2015/05/25 职场文书
出纳2015年度工作总结范文
2015/10/14 职场文书
入党申请书怎么写?
2019/06/21 职场文书
python 命令行传参方法总结
2021/05/25 Python