Node.js事件轮询机制是如何实现非阻塞IO和异步处理的?
- 内容介绍
- 文章标签
- 相关推荐
本文共计419个文字,预计阅读时间需要2分钟。
使用libuv库实现的概要事件轮询机制:
1. Timers:定时器阶段,处理即将到期的定时器回调。
2.Pending Callbacks:待处理回调阶段,执行系统操作相关的回调(如TCP错误处理)。
3.Idle/Prepare:空闲/准备阶段,处理可能长时间运行的任务。
4.Poll:轮询阶段,检查IO事件是否就绪。
借助libuv库实现的
概括事件轮询机制:分为六个阶段
1.timers 定时器阶段
计时和执行到点的定时器回调函数
2.pending callbacks
某些系统操作(例如TCP错误类型)
3.idle,prepare
4.poll轮询阶段(轮询队列)
如果轮询队列不为空,依次同步取出轮询队列中第一个回调函数,直到轮询队列为空或者达到系统最大限制
如果轮询队列为空
如果之前设置过setImmediate函数,直接进入下一个check阶段,如果之前没有设置过setImmediate函数,在当前 poll阶段等待,直到轮询队添加回调函数,就会去第一个情况执行,如果定时器到点了,他也会去下一个阶段
5.check查阶段
执行setImmediate设置的回调函数
6.close callbacks关闭阶段
close事件回调函数
process.nextTick()的意思就是定义出一个动作,pengd并且让这个动作在下一个事件轮询的时间点上执行。能在任意阶段优先执行
以上就是本次介绍的全部知识点内容,感谢大家的学习和对易盾网络的支持。
本文共计419个文字,预计阅读时间需要2分钟。
使用libuv库实现的概要事件轮询机制:
1. Timers:定时器阶段,处理即将到期的定时器回调。
2.Pending Callbacks:待处理回调阶段,执行系统操作相关的回调(如TCP错误处理)。
3.Idle/Prepare:空闲/准备阶段,处理可能长时间运行的任务。
4.Poll:轮询阶段,检查IO事件是否就绪。
借助libuv库实现的
概括事件轮询机制:分为六个阶段
1.timers 定时器阶段
计时和执行到点的定时器回调函数
2.pending callbacks
某些系统操作(例如TCP错误类型)
3.idle,prepare
4.poll轮询阶段(轮询队列)
如果轮询队列不为空,依次同步取出轮询队列中第一个回调函数,直到轮询队列为空或者达到系统最大限制
如果轮询队列为空
如果之前设置过setImmediate函数,直接进入下一个check阶段,如果之前没有设置过setImmediate函数,在当前 poll阶段等待,直到轮询队添加回调函数,就会去第一个情况执行,如果定时器到点了,他也会去下一个阶段
5.check查阶段
执行setImmediate设置的回调函数
6.close callbacks关闭阶段
close事件回调函数
process.nextTick()的意思就是定义出一个动作,pengd并且让这个动作在下一个事件轮询的时间点上执行。能在任意阶段优先执行
以上就是本次介绍的全部知识点内容,感谢大家的学习和对易盾网络的支持。

