详解nodejs异步I/O和事件循环
2017-06-07 09:20
513 查看
事件驱动模型
现在我们来看看nodejs中的事件驱动和异步I/O是如何实现的.
nodejs是单线程(single thread)运行的,通过一个事件循环(event-loop)来循环取出消息队列(event-queue)中的消息进行处理,处理过程基本上就是去调用该消息对应的回调函数。消息队列就是当一个事件状态发生变化时,就将一个消息压入队列中。
nodejs的时间驱动模型一般要注意下面几个点:
- 因为是单线程的,所以当顺序执行js文件中的代码的时候,事件循环是被暂停的。
- 当js文件执行完以后,事件循环开始运行,并从消息队列中取出消息,开始执行回调函数
- 因为是单线程的,所以当回调函数被执行的时候,事件循环是被暂停的
- 当涉及到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'); // 运行到这里之前,事件循环是暂停的
- 同步执行debug("begin")
- 异步调用fs.readFile(),此时会开一个新的线程去进行异步I/O操作
- 异步调用setTimeout(),马上将超时信息压入到消息队列中
- 同步调用debug("end")
- 开启事件循环,弹出消息队列中的信息(目前是超时信息)
- 然后执行信息对应的回调函数(事件循环又被暂停)
- 回调函数执行结束后,开始事件循环(目前消息队列中没有任何东西,文件还没读完)
- 异步I/O读取文件完毕,将消息压入消息队列(消息中含有文件内容或者是出错信息)
- 事件循环取得消息,执行回调
- 程序退出。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- nodejs异步I/O和事件循环
- 回调函数,同步调用,异步调用,事件,消息循环
- Nodejs源码的阅读-事件循环的建立
- nodejs事件循环
- JQuery在循环中绑定事件的问题详解
- NodeJS 事件系统详解
- node源码详解(六) —— 从server.listen 到事件循环
- 回调函数,同步调用,异步调用,事件,消息循环
- Node.js 的异步机制由事件和回调函数——循环中的回调函数
- 理解Node.js的事件循环(代码是异步单线程,内部实现用的还是进程和线程,基于池化的线程实现异步)
- JavaScript:彻底理解同步、异步和事件循环
- Nodejs源码的阅读-事件循环的过程
- nodejs 事件循环
- 我的Node.js学习之路(三)--node.js作用、回调、同步和异步代码 以及事件循环
- node.js的作用、回调、同步异步代码、事件循环
- muduo 24 事件循环之事件中同步和异步运行任务
- 我的Node.js学习之路(三)--node.js作用、回调、同步和异步代码 以及事件循环
- JavaScript运行机制之事件循环(Event Loop)详解
- nodejs系列(二)REPL交互解释 事件循环
- Node.js事件循环(Event Loop)和线程池详解