简介

Node.js 作为 JavaScript 后端运行环境,其核心优势在于高并发处理能力和非阻塞 I/O 模型。

特点:

  • 高并发处理:单线程事件循环高效处理大量并发连接
  • I/O 密集型任务:非阻塞 I/O 模型避免线程切换开销,不适合 CPU 密集型任务(如视频编码)
  • 前后端技术统一:JavaScript 全栈开发

注意:
Node.js 不是多线程的,主线程是单线程,但通过线程池处理部分操作

使用场景

  • Web 服务器(如 REST API)
  • 实时应用(如聊天、协作工具)
  • 微服务架构中的网关 / 代理服务
  • 数据管道和流处理

分层架构

  1. 底层系统
    • 操作系统:Linux、Windows、macOS 等
    • 系统调用:文件操作、网络通信等底层 API
  2. C/C++ 核心库
    • V8 引擎:Google 开发的 JavaScript 执行引擎,负责编译和执行 JS 代码
    • libuv:Node.js 自主开发的跨平台异步 I/O 库,封装操作系统底层 API
    • OpenSSL:提供加密和安全通信功能
    • zlib:压缩 / 解压缩数据
  3. JavaScript 核心模块
    • 如 fs(文件系统)、net(网络)、http(HTTP 服务器)等,通过 Node.js 绑定层调用底层 C/C++ 库
  4. 用户应用层
    开发者编写的 Node.js 应用代码

事件循环

Node.js 的事件循环(Event Loop)是其异步 I/O 的核心机制,由 Libuv 库实现。它将事件循环分为 7 个主要阶段,每个阶段按特定顺序执行不同类型的回调任务。以下是各阶段的详细说明:

  1. timers 阶段(定时器阶段)
  2. pending callbacks 阶段(待定回调阶段)
  3. idle, prepare 阶段(内部准备阶段)
  4. poll 阶段(轮询阶段)
  5. check 阶段(检查阶段)
  6. close callbacks 阶段(关闭回调阶段)
  7. nextTick 与 microtasks(穿插执行,不属于主阶段)

在这里插入图片描述

setTimeout 与 setImmediate 的执行顺序

在 Node.js 中,setTimeout 和 setImmediate 的执行顺序取决于它们的调用位置和事件循环的状态。这是一个常见的面试考点,也是理解 Node.js 异步机制的关键。

核心区别

  1. setTimeout(callback, 0)
  • 理论上立即执行回调,但实际延迟 ≥ 1ms(受系统调度影响)。
  • 回调在事件循环的 Timer 阶段执行。
  1. setImmediate()
  • 设计用于在当前轮询阶段结束后立即执行回调。
  • 回调在事件循环的 Check 阶段执行。

执行顺序

  1. 在主模块中调用的时候
    当两者在主模块中调用的时候,执行顺序不固定,取决于 JavaScript 引擎的初始化速度和系统负载。
// 示例1:主模块中直接调用
setTimeout(() => {console.log('定时器回调');
}, 0);setImmediate(() => {console.log('setImmediate 回调');
});// 可能的输出:
// 1. 定时器回调 → setImmediate 回调(常见情况)
// 2. setImmediate 回调 → 定时器回调(极少情况,系统负载高时可能发生)

原因

  • setTimeout(…, 0) 实际延迟 ≥ 1ms,如果系统繁忙,可能超过 1ms。
  • 如果延迟超过 1ms,事件循环进入 Check 阶段时,定时器尚未触发,导致 setImmediate 先执行。
  1. 在异步 I/O 回调中调用
    当两者在异步 I/O 回调(如 fs.readFile)中调用时,setImmediate 总是先于 setTimeout 执行。
// 示例2:在I/O回调中调用
const fs = require('fs');fs.readFile(__filename, () => {setTimeout(() => {console.log('定时器回调');}, 0);setImmediate(() => {console.log('setImmediate 回调');});
});// 输出顺序固定为:
// setImmediate 回调 → 定时器回调

原因

  • 异步 I/O 回调在Poll 阶段执行。
  • 执行完毕后,事件循环进入Check 阶段,执行 setImmediate 的回调。
  • 下一轮循环的 Timer 阶段才会执行 setTimeout 的回调。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/85772.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/85772.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/85772.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nginx服务器配置时遇到的一些问题

京东云 CentOS 8.2 64位 Nginx配置文件修改后需要重启或重载服务的原因以及不重启的后果: ​​工作进程不主动重读配置​​: Nginx采用master-worker多进程架构。master进程读取配置文件并管理worker进程,worker进程处理实际请求。修改配置…

【论文阅读 | CVPR 2024 |Fusion-Mamba :用于跨模态目标检测】

论文阅读 | CVPR 2024 |Fusion-Mamba :用于跨模态目标检测 1.摘要&&引言2.方法2.1 预备知识2.2 Fusion-Mamba2.2.1 架构特征提取与多模态融合(FMB模块)FMB的应用与输出2.2.2 关键组件3.2.2.1 SSCS 模块:浅层跨模态特征交互…

Nginx-Ingress-Controller自定义端口实现TCP/UDP转发

背景1 使用deployment部署一个http服务,配合使用ingresstls的解析在ingress终止。 apiVersion: networking.k8s.io/v1 kind: Ingress metadata:annotations:name: test.comnamespace: rcs-netswitch-prod spec:defaultBackend:service:name: rcs-netswitch-prodpo…

基于Vue.js的图书管理系统前端界面设计

一、系统前端界面设计要求与效果 (一)系统功能结构图 设计一个基于Vue.js的图书管理系统前端界面。要充分体现Vue的核心特性和应用场景,同时结合信息管理专业的知识。要求系统分为仪表盘、图书管理、借阅管理和用户管理四个主要模块&#x…

Perplexity AI:对话式搜索引擎的革新者与未来认知操作系统

在信息爆炸的数字时代,传统搜索引擎提供的海量链接列表已无法满足用户对高效、精准知识获取的需求。Perplexity AI作为一款融合人工智能与实时网络检索的对话式搜索引擎,正通过技术创新重新定义人们获取信息的方式。这家成立于2022年的硅谷初创企业&…

第七讲 信号

1. 信号铺垫 信号: Linux 系统提供的, 简单轻量的, 用于向指定进程发送特定事件, 让接受信号进程做识别和对应处理实现进程控制的一种异步通信机制. 1~31 普通信号 34 ~ 64 实时信号 信号概览 下面是Linux系统中所有标准信号的名称及其对应的数字: SIGHUP (1…

2025年渗透测试面试题总结-2025年HW(护网面试) 02(题目+回答)

安全领域各种资源,学习文档,以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具,欢迎关注。 目录 2025年HW(护网面试) 02 1. 有趣的挖洞经历 2. 高频漏洞及修复方案 3. PHP/Java反序列化漏洞 4. 服务器入…

Odoo 18进阶开发:打造专业级list,kanban视图Dashboard

🎯 项目概述 在现代企业级应用中,数据可视化已成为提升用户体验的关键要素。Odoo 18 作为领先的企业资源规划系统,为开发者提供了强大的视图定制能力。本教程将带您深入了解如何在list(列表)视图和Kanban(…

LabVIEW仪表检测

依托LabVIEW 图形化开发平台,集成 NI、Keysight、Fluke 等硬件,构建自动化仪表检测工装系统。方案覆盖从二维码识别、程序烧写、多维度校准到数据管理的全流程自动化检测,解决传统人工检测中效率低下(单卡检测效率提升 62.5%&…

Java八股文——消息队列「场景篇」

什么是消息队列? 面试官您好,消息队列(Message Queue, MQ),从本质上讲,是一个实现了“先进先出”(FIFO)队列数据结构的、专门用于在不同系统或服务之间进行可靠异步通信的中间件。 …

CTE vs 子查询:深入拆解PostgreSQL复杂SQL的隐藏性能差异

1 SQL优化的关键抉择 在PostgreSQL数据库性能优化领域,CTE(公共表表达式) 和子查询的选择往往决定了复杂SQL查询的执行效率。许多开发者习惯性地认为两者功能等价,但实际执行路径却存在显著差异。本文将深入剖析两者的底层机制&a…

【fargo】x264的intra refresh 1:编码

【fargo】x264的intra refresh 2:识别NAL类型、 NAL slice header 解析器大神的理论分析: H264Encoder 编码输出一帧 D:\XTRANS\thunderbolt\ayame\zhb-bifrost\player-only\echo\codec\x264\echo_h264_encoder.cppbool H264Encoder::encode

npm下载离线依赖包

项目中需要用到mermaid以来,使用npm安装: npm install mermaid 但是客户现场是离线环境,无法直接使用npm install mermaid安装,所以需要考虑下载离线依赖包,命令为: npm pack mermaid 下载后&#xff1…

【教程】不同架构(armv7l等)下载Miniconda安装包

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~ 目录 armv7l架构 aarch、arm、x86架构 armv7l架构 wget http://repo.continuum.io/miniconda/Miniconda3-latest-Linux-armv7l.sh bash Miniconda3-…

【C++特殊工具与技术】嵌套类

在 C 中,类的嵌套(Nested Class)是一种强大的封装手段。通过将一个类定义在另一个类(称为外围类,Enclosing Class)的内部,我们可以将关联紧密的功能逻辑集中管理,同时限制嵌套类的作…

Python安装cartopy报错,解决cartopy环境配置问题

1、尝试过各种办法,说依赖包的问题,下载了没用,说版本问题没用。conda安装成功了,运行仍然报错。采用了一个笨办法解决(高效便捷)。 用 conda-forge 重建环境,因为依赖混乱,重新创建…

python实战项目77:足球运动员数据分析

python实战项目77:足球运动员数据分析 一、数据集介绍二、加载数据集三、查看数据3.1 查看数据大小3.2 查看数据前几行3.3 查看数据基本信息四、数据预处理4.1 查看并处理缺失值4.2 查看并处理重复值五、运动员身高和体重分布5.1 查看身高和体重列数据情况5.2 数据类型转换5.3…

安卓官方版fat-aar:使用Fused Library将多个Android库发布为一个库

安卓官方版fat-aar:使用Fused Library将多个Android库发布为一个库 - Wesley’s Blog 在开发 sdk 时,内部一般会划分好几个模块。但当需要打包成一个模块发布时,往往需要依赖第三方插件。比如著名的 fat-aar:https://github.com/kezong/fat-…

VR看房:重塑房地产行业生态的技术革命

在科技浪潮的席卷下,虚拟现实(VR)技术正深刻重塑房地产行业格局。VR看房这一创新模式的兴起,打破了传统看房的诸多限制,从根本上变革了购房者的看房体验,也为房地产企业的运营带来全新契机与挑战。 一、VR…

vscode+react+ESLint解决不引入组件,vscode不会报错的问题

解决不引入组件&#xff0c;vscode不会报错的问题 routes.jsx 全部代码如下 export const routes [{path:"/",element:<Home/>} ]在项目根目录下新建个 eslint.config.js 加入下面的代码&#xff0c;要保证node_modules里安装了 eslint-plugin-react&a…