【前端学习——js篇】5.事件循环

news/2024/4/27 22:27:34/文章来源:https://blog.csdn.net/qq_44061175/article/details/137008234

详细:https://github.com/febobo/web-interview

5.事件循环

js是一种单线程语言,同一时间内只能做一件事情,为了避免单线程阻塞的方法就是事件循环。

在javascript当中,所有的任务都可以分为:

  • 同步任务:按顺序执行的任务,一个任务的执行必须等待前一个任务的完成。同步任务一般会直接进入主线程执行。

  • 异步任务:不按顺序执行的任务,可以在后台执行,不会阻塞代码的执行。比如:ajax网络请求,setTimeout,setinterval定时函数等,Promiseasync/await等。


在这里插入图片描述

同步任务进入主线程,即主执行栈,异步任务进入任务队列,主线程内的任务执行完毕为空,会去任务队列读取对应的任务,推入主线程执行。上述过程的不断重复就事件循环。

①宏任务与微任务

在JavaScirpt当中,宏任务(macrotask)和微任务(microtask)是异步任务的两种类型,它们有不同的执行时机和优先级。

宏任务(macrotask)

  • 宏任务代表的是一组任务的执行,可以看作是每一个独立的、完整的任务。

  • 常见的宏任务包括整体的代码块(scirpt)、setTimeout、setInterval、I/O操作、UI渲染等。

  • 当执行栈中的任务执行完毕后,js运行时会检查是否有宏任务需要执行,然后选择一个宏任务执行,执行完后再次清空执行栈。


微任务(microtask)

  • 相对于更“细粒度”的任务,执行时机位于当前任务执行结束后、下一个宏任务开始之前。

  • 常见的微任务包括Promise的处理、MutationObserver变动观察器等。

  • 微任务通常用于处理异步操作的结构,其优先级高于宏任务,及在当前宏任务执行完毕后,会优先执行微任务队列中的任务,直到微任务队列为空,才会执行下一个宏任务。


在执行顺序上,JavaScript 的事件循环(Event Loop)会先执行当前执行栈中的任务,然后检查是否有微任务需要执行,如果有,会依次执行微任务队列中的所有任务,直到微任务队列为空;最后再执行下一个宏任务。这样的循环过程不断重复,直到所有任务执行完毕。

在这里插入图片描述

console.log(1)setTimeout(()=>{console.log(2)
}, 0)new Promise((resolve, reject)=>{console.log('new Promise')resolve()
}).then(()=>{console.log('then')
})console.log(3)

如果按照上面流程图来分析代码,我们会得到下面的执行步骤:

1.console.log(1):首先会打印出 1,因为这是同步代码,会立即执行并输出 12.遇到 setTimeout,会将回调函数推入宏任务队列,等待当前执行栈清空后执行。3.遇到 Promise 对象,会立即执行 Promise 的构造函数中的代码,输出 new Promise(1)紧接着,resolve() 会立即执行,表示 Promise 状态变为 resolved,进入 then 方法的回调链。(2)由于 Promise 的状态是 resolved,所以 then 方法中的回调函数会被放入微任务队列中等待执行。(3)接着会打印出 3,因为这是同步代码,会立即执行并输出 34.此时宏任务执行完成,开始执行微任务队列执行 then 方法,输出 then5. 当一次宏任务执行完,再去执行新的宏任务,这里就剩一个定时器的宏任务了,执行它,输出 2

结果是:1=>'new Promise'=> 3 => 'then' => 2

详情可见Jake的博客:Tasks, microtasks, queues and schedules,这篇文章非常经典。

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

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

相关文章

Linux 系统 docker搭建LNMP环境

1、安装nginx docker pull nginx (默认安装的是最新版本) 2、运行nginx docker run --name nginx -p 80:80 -d nginx:latest 备注:--name nginx 表示容器名为 nginx -d 表示后台运行 -p 80:80 表示把本地80端口绑定到Nginx服务端的 80端口 nginx:lates…

基于51单片机的拔河游戏Proteus仿真

地址:https://pan.baidu.com/s/18LMEo-_WYcoyTOkWYJ0NUg 提取码:1234 仿真图: 1)设计一个能进行拔河游戏的电路,通过按键控制游戏开始和复位。 2)电路使用9个发光二极管排成一行,中间的LED为拔…

第二百二十八回

文章目录 1. 概念介绍2. 修改方法2.1 修改形状2.2 修改颜色2.3 修改位置 3. 示例代码4. 内容总结 我们在上一章回中介绍了"如何创建以图片为背景的页面"相关的内容,本章回中将介绍如何修改按钮的形状.闲话休提,让我们一起Talk Flutter吧。 1. …

动态规划课堂7-----两个数组的dp问题(等价代换)

目录 引言: 例题1:最长公共子序列 例题2:不同的子序列 例题3:通配符匹配 例题4:正则表达式 结语: 引言: 本节我们就要进入两个数组的dp问题的学习,通过前面几个章节的学习&…

终于来了!FastGPT 正式兼容 GPT 应用

终于来了!FastGPT 正式兼容 GPT 应用 FastGPT V4.7 正式加入了工具调用功能,可以兼容 GPTs 的 Actions。这意味着,你可以直接导入兼容 GPTs 的 Agent 工具! Gapier 是一组无需编码,开箱可用的,并且已经适配…

快速入门go语言

环境搭建 编译器安装 1、编译器下载地址 2、打开命令行模式,输入go version ide安装 ide下载地址 依赖管理 goproxy 1、goproxy代理地址 // 阿里云 https://mirrors.aliyun.com/goproxy // 微软 https://goproxy.io // 七牛 https://goproxy.cn 2、ide配置g…

蚂蚁庄园今日答案

蚂蚁庄园是一款爱心公益游戏,用户可以通过喂养小鸡,产生鸡蛋,并通过捐赠鸡蛋参与公益项目。用户每日完成答题就可以领取鸡饲料,使用鸡饲料喂鸡之后,会可以获得鸡蛋,可以通过鸡蛋来进行爱心捐赠。其中&#…

UG NX二次开发(C#)-通过曲线组生成NURBS曲面

文章目录 1、前言2、UG NX中通过曲线组生成NURBS曲面的操作3、采用NXOpen C#方法的源代码1、前言 在UG NX中,曲线、曲面的操作使用比较多,对于创建NURBS曲面,可以通过曲线组来生成,本文以NXOpen C#的方法实现通过曲线组生成NURBS曲面的功能。对于UG NX二次开发感兴趣或者有…

windows上打开redis服务闪退问题处理

方法1:在windows上面打开redis服务时,弹窗闪退可能是6379端口占用,可以用以下命令查看: netstat -aon | findstr 6379 如果端口被占用可以用这个命令解决: taskkill /f /pid 进程号 方法2: 可以使用…

力扣热门算法题 112. 路径总和,115. 不同的子序列,120. 三角形最小路径和

112. 路径总和,115. 不同的子序列,120. 三角形最小路径和,每题做详细思路梳理,配套Python&Java双语代码, 2024.03.25 可通过leetcode所有测试用例。 目录 112. 路径总和 解题思路 完整代码 Java Python 115…

机器学习——元学习

元学习(Meta Learning)是一种机器学习方法,旨在使模型能够学习如何学习。它涉及到在学习过程中自动化地学习和优化学习算法或模型的能力。元学习的目标是使模型能够从有限的训练样本中快速适应新任务或新环境。 在传统的机器学习中&#xff…

数据结构算法系列----贪心算法

目录 一、什么是贪心 1、定义: 2、举例: 二、例题 完整代码: 一、什么是贪心 1、定义: 贪心算法是一种在每一步选择中都采取当前状态下最优决策的算法。在贪心算法中,通过 局部最优 解来达到全局最优解。贪心算法…

Mysql数据库:事务管理

目录 一、Mysql事务的概述 1、Mysql事务的概念 2、事务的ACID四大特性 3、事务之间的相互影响 4、事务的四种隔离级别 5、MySQL与Oracle自动提交事务的区别 6、事务隔离级别的作用范围 二、Mysql事务相关操作 1、查询和设置事务隔离级别 1.1 全局级事务隔离级别 1.1…

量子计算+运营优化!IonQ 和 德国DESY 合作提升机场登机口调度效率

内容来源:量子前哨(ID:Qforepost) 编辑丨慕一 编译/排版丨 沛贤 深度好文:1200字丨8分钟阅读 3月14日,量子计算公司IonQ宣布了与德国电子同步加速器(DESY,德国的大型粒子物理学研…

【正点原子FreeRTOS学习笔记】————(2)FreeRTOS的任务创建和删除

这里写目录标题 一、任务创建和删除的API函数(熟悉)二、任务创建和删除(动态方法)(掌握)三、任务创建和删除(静态方法)(掌握) 一、任务创建和删除的API函数&a…

数据结构:初识树和二叉树

目前主流的方式是左孩子右兄弟表示法 我们的文件系统就是一个树 以上就是树的概念,我们今天还要来学习一种从树演变的重要的结构:二叉树 顾名思义二叉树就是一个结点最多有两个子树。 其中我们还要了解满二叉树和完全二叉树的概念 注意我们的完全二叉…

Java项目:78 springboot学生宿舍管理系统的设计与开发

作者主页:舒克日记 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 系统的角色:管理员、宿管、学生 管理员管理宿管员,管理学生,修改密码,维护个人信息。 宿管员管理公寓…

微服务高级篇(三):分布式缓存+Redis集群

文章目录 一、单点Redis的问题及解决方案二、Redis持久化2.1 单机安装Redis2.2 RDB持久化2.3 AOF持久化2.4 RDB和AOF对比 三、Redis主从3.1 搭建Redis主从架构3.1.1 集群结构3.1.2 准备实例和配置3.1.3 启动3.1.4 开启主从关系3.1.5 测试 3.2 数据同步3.2.1 全量同步【建立连接…

盏燕生物科技将出席2024第七届燕窝天然滋补品博览会

参展企业介绍 深圳市盏燕生物科技有限公司,办公室地址位于中国第一个经济特区,鹏城深圳,深圳市龙岗区平湖街道禾花社区富安大道18号亚钢工贸大楼1栋1017A,我公司主要提供一般经营项目是:初级农产品、海产品、化妆品、…

批量添加时,两个选择框为一组,不能选择一模一样的值,将不符合条件的值禁止设为禁止点击

效果展示&#xff1a; 完整代码如下&#xff1a; <template><div class"container"><div v-for"item in arr"><el-select v-model"item.name" placeholder"请选择" change"changeBox"><el-opti…