nodejs的Event loop

1. nodejs的宏任务回调有6个阶段:

timers              setTimeout setInterval

IO                     fs.read, fs.write, network

idle prepare      准备工作,node内部使用

poll                   新加入的IO事件

check               setImmediate回调

close                close事件的回调,例如 socket.on('close', ...)

2. nodejs的宏任务和微任务

宏任务队列有4个:

1. timers Queue
2. IO Queue
3. check Queue
4. close Queue

微任务队列有2个:

1. nextTick Queue          process.nextTick
2. other Micro Queue      Promise等

3. nodejs的Event loop过程

1. 执行全局script同步代码
2. 执行微任务,nextTick Queue,再次other Micro Queue,直至清空
3. 宏任务与微任务交替执行
    老版本Node 宏任务每个阶段与微任务交替执行,timers Queue -> 微任务 -> IO Queue -> 微任务 -> check Queue -> 微任务 -> close Queue -> 微任务 -> ...
    新版本Node 宏任务一个 -> 微任务 -> 宏任务一个 -> 微任务 -> ...

因此,process.nextTick在每个宏任务前都能优先执行。

posted @   全玉  阅读(166)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示