详解nodejs异步I/O和事件循环


Posted in NodeJs onJune 07, 2017

事件驱动模型

现在我们来看看nodejs中的事件驱动和异步I/O是如何实现的.

nodejs是单线程(single thread)运行的,通过一个事件循环(event-loop)来循环取出消息队列(event-queue)中的消息进行处理,处理过程基本上就是去调用该消息对应的回调函数。消息队列就是当一个事件状态发生变化时,就将一个消息压入队列中。

nodejs的时间驱动模型一般要注意下面几个点:

  1. 因为是单线程的,所以当顺序执行js文件中的代码的时候,事件循环是被暂停的。
  2. 当js文件执行完以后,事件循环开始运行,并从消息队列中取出消息,开始执行回调函数
  3. 因为是单线程的,所以当回调函数被执行的时候,事件循环是被暂停的
  4. 当涉及到I/O操作的时候,nodejs会开一个独立的线程来进行异步I/O操作,操作结束以后将消息压入消息队列。

下面我们从一个简单的js文件入手,来看看 nodejs是如何执行的。

var fs = require("fs");
var debug = require('debug')('example1');

debug("begin");

fs.readFile('package.json','utf-8',function(err,data){
 if(err) 
  debug(err);
 else
  debug("get file content");
});

setTimeout(function(){
 debug("timeout2");
});

 
debug('end'); // 运行到这里之前,事件循环是暂停的
  1. 同步执行debug("begin")
  2. 异步调用fs.readFile(),此时会开一个新的线程去进行异步I/O操作
  3. 异步调用setTimeout(),马上将超时信息压入到消息队列中
  4. 同步调用debug("end")
  5. 开启事件循环,弹出消息队列中的信息(目前是超时信息)
  6. 然后执行信息对应的回调函数(事件循环又被暂停)
  7. 回调函数执行结束后,开始事件循环(目前消息队列中没有任何东西,文件还没读完)
  8. 异步I/O读取文件完毕,将消息压入消息队列(消息中含有文件内容或者是出错信息)
  9. 事件循环取得消息,执行回调
  10. 程序退出。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
nodejs入门详解(多篇文章结合)
Mar 07 NodeJs
nodejs分页类代码分享
Jun 17 NodeJs
NodeJS学习笔记之(Url,QueryString,Path)模块
Jan 13 NodeJs
windows下安装nodejs及框架express
Aug 07 NodeJs
nodejs处理图片的中间件node-images详解
May 08 NodeJs
nodejs 子进程正确的打开方式
Jul 03 NodeJs
nodejs实现简单的gulp打包
Dec 21 NodeJs
NodeJS 中Stream 的基本使用
Jul 30 NodeJs
nodejs中用npm初始化来创建package.json的实例讲解
Oct 10 NodeJs
通过实例了解Nodejs模块系统及require机制
Jul 16 NodeJs
nodejs中使用worker_threads来创建新的线程的方法
Jan 22 NodeJs
浅析 NodeJs 的几种文件路径
Jun 07 #NodeJs
nodejs mysql 实现分页的方法
Jun 06 #NodeJs
nodejs利用ajax实现网页无刷新上传图片实例代码
Jun 06 #NodeJs
ajax +NodeJS 实现图片上传实例
Jun 06 #NodeJs
详解Nodejs之静态资源处理
Jun 05 #NodeJs
nodejs集成sqlite使用示例
Jun 05 #NodeJs
详解nodeJS之二进制buffer对象
Jun 03 #NodeJs
You might like
PHP的宝库目录--PEAR
2006/10/09 PHP
PHP使用glob函数遍历目录或文件夹的方法
2014/12/16 PHP
Laravel 模型关联基础教程详解
2019/09/17 PHP
jQuery EasyUI API 中文文档 - ComboGrid 组合表格
2011/10/13 Javascript
屏蔽网页右键复制和ctrl+c复制的js代码
2013/01/04 Javascript
jfreechart插件将数据展示成饼状图、柱状图和折线图
2015/04/13 Javascript
JavaScript从数组的indexOf()深入之Object的Property机制
2016/05/11 Javascript
一步一步封装自己的HtmlHelper组件BootstrapHelper(二)
2016/09/14 Javascript
JQuery手速测试小游戏实现思路详解
2016/09/20 Javascript
jQuery Ajax请求后台数据并在前台接收
2016/12/10 Javascript
完美解决input[type=number]无法显示非数字字符的问题
2017/02/28 Javascript
怎样在vue项目下添加ESLint的方法
2019/05/16 Javascript
了解JavaScript中的选择器
2019/05/24 Javascript
详解ng-alain动态表单SF表单项设置必填和正则校验
2019/06/11 Javascript
JavaScript代码实现简单计算器
2020/12/27 Javascript
利用打码兔和超人打码自封装的打码类分享
2014/03/16 Python
Python下Fabric的简单部署方法
2015/07/14 Python
Python内置模块hashlib、hmac与uuid用法分析
2018/02/12 Python
彻彻底底地理解Python中的编码问题
2018/10/15 Python
Python 监测文件是否更新的方法
2019/06/10 Python
python之拟合的实现
2019/07/19 Python
pip install python 快速安装模块的教程图解
2019/10/08 Python
Django多层嵌套ManyToMany字段ORM操作详解
2020/05/19 Python
html5触摸事件判断滑动方向的实现
2018/06/05 HTML / CSS
详解HTML5中ol标签的用法
2015/09/08 HTML / CSS
如何开启linux的ssh服务
2013/06/03 面试题
化工工艺专业求职信
2013/09/22 职场文书
社区七一党员活动方案
2014/01/25 职场文书
绩效管理实施方案
2014/03/19 职场文书
致共产党员倡议书
2014/04/16 职场文书
通信工程求职信
2014/07/16 职场文书
教师四风问题整改措施
2014/09/25 职场文书
2015年禁毒宣传活动总结
2015/03/25 职场文书
药店收银员岗位职责
2015/04/07 职场文书
运动会通讯稿50字
2015/07/20 职场文书
陶瓷类经典广告语集锦
2019/10/25 职场文书