博客
关于我
Node.js 的事件循环(Event Loop)详解
阅读量:793 次
发布时间:2023-02-16

本文共 1852 字,大约阅读时间需要 6 分钟。

还是大剑师兰特:曾是美国某知名大学计算机专业研究生,现为航空航海领域高级前端工程师;CSDN知名博主,GIS领域优质创作者,深耕openlayers、leaflet、mapbox、cesium,canvas,webgl,echarts等技术开发,欢迎加底部微信(gis-dajianshi),一起交流。

在这里插入图片描述

No. 大剑师精品GIS教程推荐
0 地图渲染基础- - -
1 Openlayers -
2 Leaflet -
3 MapboxGL -
4 Cesium -
5 threejs -
6 Shader 编程
7 Geoserver
8 卫星应用开发教程
9 GIS数字孪生与大模型
10 报表与数字大屏 - -

文章目录


在这里插入图片描述

Node.js 的事件循环(Event Loop)是其非阻塞I/O和高并发能力的核心机制,它基于JavaScript的单线程异步执行模型。事件循环允许Node.js在不创建额外线程的情况下处理并发操作,特别是对于I/O密集型任务非常有效。以下是事件循环的基本组成部分和工作流程,以及一个简单示例来帮助理解。

一、事件循环阶段

事件循环可以大致分为以下几个阶段:

  1. Timers(定时器):处理setTimeoutsetInterval的回调。
  2. I/O Polling(I/O轮询):检查是否有已完成的I/O操作,如文件读写、网络请求等,如果有,则执行相应的回调。
  3. Idle, Prepare(空闲、准备):内部操作,对外部透明。
  4. Check(检查):处理setImmediate的回调。
  5. Close Callbacks(关闭回调):处理如socket.on('close', ...)这类关闭事件的回调。

完成所有阶段后,事件循环会再次从Timers阶段开始,不断循环,直到没有更多的任务需要处理。

二、循环示例代码

下面的示例代码演示了setTimeoutsetImmediate在事件循环中的执行顺序,帮助理解它们之间的区别。

const fs = require('fs');const {    promisify } = require('util');const readFile = promisify(fs.readFile);async function main() {     console.log('Start');  // 使用setTimeout模拟定时器任务  setTimeout(() => {       console.log('setTimeout callback');  }, 0);  // 使用setImmediate模拟立即执行但排队在I/O之后的任务  setImmediate(() => {       console.log('setImmediate callback');  });  // 模拟一个I/O操作  try {       await readFile('test.txt', 'utf8');    console.log('File read');  } catch (err) {       console.error(err);  }  console.log('End of main function');}main();

三、输出分析

假设test.txt文件存在且读取成功,可能的输出如下:

StartEnd of main functionFile readsetImmediate callbacksetTimeout callback

这是因为:

  • Start首先打印。
  • setTimeout虽然设置了0延迟,但它仍会被放入Timers队列,不会立即执行。
  • setImmediate被安排在Check阶段执行。
  • readFile是一个I/O操作,事件循环会先进入I/O Polling阶段,等待该操作完成,因此File readsetImmediate callback之前打印。
  • End of main function紧接着主函数执行完毕后打印,此时事件循环有机会处理Timers队列中的setTimeout回调。
  • 由于没有其他I/O操作正在进行,事件循环继续进行,处理Check阶段的setImmediate回调。

注意,实际的输出可能会因为Node.js版本、操作系统等因素略有不同,但基本原理不变。理解事件循环对于写出高效、可预测的Node.js应用至关重要。

转载地址:http://cpjfk.baihongyu.com/

你可能感兴趣的文章
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>