当前位置: 首页 > news >正文

JS相关八股之什么是事件循环

在JavaScript中,“事件循环”(Event Loop)是一个非常重要的概念,它是指JavaScript引擎如何在单线程中处理异步操作的机制。单线程意味着在任意时刻,JavaScript代码只能执行一个任务。

一.事件循环的工作流程大致如下:

  1. 执行栈(Call Stack)

    • 当一个脚本开始执行时,它首先会进入执行栈。这里会按照顺序执行代码中的函数调用。
    • 执行栈是一个LIFO(后进先出)结构,最新添加到栈的任务会被首先完成。当前正在执行的函数将位于栈顶。
  2. 任务队列(Task Queue)

    • 当异步事件(如setTimeoutsetInterval、I/O、UI事件等)到达预定目标时,相应的回调函数会被放入任务队列。
    • 这些回调函数会等待当前执行栈中的所有任务都完成,即执行栈被清空。
  3. 事件循环

    • 一旦执行栈空了,事件循环就会从任务队列中取出排在最前面的任务,然后将其放入执行栈中去执行。
    • 这个过程是循环进行的,因此被称作“事件循环”。

二.宏任务与微任务:

在现代JavaScript引擎中,任务队列又被分为宏任务(Macro Task)队列和微任务(Micro Task)队列。

  • 宏任务:包括setTimeoutsetInterval、I/O、UI事件等。
  • 微任务:包括Promise的回调、Object.observe的变化回调、MutationObserver的回调等。

执行栈为空时,事件循环首先会检查微任务队列。如果微任务队列不为空,事件循环会连续执行微任务队列中所有的任务,直到微任务队列为空。之后,事件循环才会执行一个宏任务。完成宏任务后,事件循环又会检查微任务队列,这个过程会反复进行。

这种机制确保了微任务有更高的优先级和更快的响应时间,因为它们不需要等待下一轮事件循环。

事件循环是JavaScript实现异步编程的核心,它允许JavaScript引擎在执行长时间运行的任务时,仍然可以处理UI更新,接收用户输入,以及在合适的时间执行异步操作的回调。理解事件循环对于编写高效的异步代码至关重要。

http://www.lryc.cn/news/340717.html

相关文章:

  • SpringCloud集成Skywalking链路追踪和日志收集
  • HTTP 域名和主机是一回事吗?有了主机和域名,如何建站?
  • 运营干货:四个技巧掌握爆款选题方法
  • 柯桥商务口语之怎么样说英语更加礼貌?十个礼貌用语get起来!
  • 嵌入式工程师如何摸鱼?
  • C++语言题库(一)—— 基本知识类
  • gemini1.5 API调用
  • C++从入门到精通——const与取地址重载
  • 手写spring IOC底层源码来模拟spring如何利用多级缓存解决循环依赖的问题
  • C++11 Thead线程和线程池
  • Windows版Apache 2.4.59解压直用(免安装-绿色-项目打包直接使用)
  • 刀具表面上的微结构
  • css3实现微信扫码登陆动画
  • vue3 导入excel数据
  • C# linq 根据多字段动态Group by
  • C语言学习/复习22----阶段测评编程题
  • LeetCode-1766. 互质树【树 深度优先搜索 广度优先搜索 数组 数学 数论】
  • “数据安全服务能力”评定资格认证!不容错过
  • 【MATLAB 分类算法教程】_3麻雀搜索算法优化支持向量机SVM分类 - 教程和对应MATLAB代码
  • 利用机器学习库做动态定价策略的例子
  • Tcpdump -r 解析pcap文件
  • [dvwa] sql injection(Blind)
  • linux 挂载云盘 NT只能挂载2T,使用parted挂载超过2T云盘
  • 用Skimage学习数字图像处理(021):图像特征提取之线检测(下)
  • ArduPilot飞控之Gazebo + SITL + MP的Jetson Orin环境搭建
  • 前端错误监控的方法有哪些
  • ✌粤嵌—2024/3/11—跳跃游戏
  • Docker入门实战教程
  • 数据结构初阶:二叉树(一)
  • 基于逻辑回归和支持向量机的前馈网络进行乳腺癌组织病理学图像分类