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

详细: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.mzph.cn/news/776170.shtml

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

相关文章

Windows10 Version22h2 补丁kb5034441更新失败

By wdhuag 20240328 参考: Windows10安装KB5034441更新报错0x80070643_2024-01 适用于 windows 10 version 22h2 安全更新,适合基于 x64 -CSDN博客 windows10(KB5034441)更新失败报错 0x80070643解决方法_kb5034441更新失败-CSDN博客 如何修复 Windo…

07|Java IO流与网络编程入门教程:通俗易懂,实例丰富

一、IO流概念与应用 什么是IO流? 想象一下水管流水,水从一端流入流出的过程就像是数据在程序中的传输。在Java世界里,IO流就是这样一个抽象概念,它是数据在不同存储介质或网络之间传输的一种方式。简单来说,如果你把数据看作水流,那么IO流就是承载这个水流的管道,它可以…

01.ArcEngine中IField的属性详细描述

目录 0.代码样例 1. AliasName 2.CheckValue 3.DefaultValue 4.Domain 5.DomainFixed 6.Editable 7.GeometryDef 8.IsNullable 9.Length 10.Name 11.Precision 12.Required 13.Scale 14.Type 15.VarType 0.代码样例 IFields fields featureclass…

双通道内存@DDR5多通道内存

文章目录 多通道内存DDR4及以前的内存的双通道DDR5往后的双通道和多通道半位宽4通道组合 其他组合测试 DDR5介绍概览重要Features特点 总结 多通道内存 DDR4及以前的内存的双通道 双通道内存是一种内存架构设计,通过在主板上配置两个或多个独立且同时工作的内存控制…

管理阿里云服务器ECS -- 网站选型和搭建

小云:我已经学会了如何登录云服务器ECS了,但是要如何搭建网站呢? 老王:目前有很多的个人网站系统软件,其中 WordPress 是使用非常广泛的一款,而且也可以把 WordPress 当作一个内容管理系统(CMS…

使用yolov9来实现人体姿态识别估计(定位图像或视频中人体的关键部位)教程+代码

yolov9人体姿态识别: 相较于之前的YOLO版本,YOLOv9可能会进一步提升处理速度和精度,特别是在姿态估计场景中,通过改进网络结构、利用更高效的特征提取器以及优化损失函数等手段来提升对复杂人体姿态变化的捕捉能力。由于YOLOv9的…

架构师之路--docker命令实践整理

安装docker sudo yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-engine sudo yum install -y yum-utils sudo yum-config-manager --add-repo http://mirrors.aliyun.com/…

开源博客项目Blog .NET Core源码学习(12:App.Application项目结构分析)

开源博客项目Blog的App.Application项目主要定义网站页面使用的数据类,同时定义各类数据的增删改查操作接口和实现类。App.Application项目未安装Nuget包,主要引用App.Core项目的类型。   App.Application项目的顶层文件夹如下图所示,下面逐…

巨控GRM110系列:短距离内的无线通讯模块

标签: #巨控GRM110 #无线通讯 #ROLA技术 #工业自动化 #远程数据采集 在工业自动化和智能制造的领域中,数据的准确传输是实现高效生产的关键。随着技术的不断进步,无线通讯技术已成为破解远距离数据传输难题的利器。今天,我们将聚焦于一款革命…

U盘未格式化?数据恢复大揭秘!

在日常办公和生活中,U盘已成为我们不可或缺的数据存储工具。然而,有时我们会遇到这样一个令人头疼的问题:原本正常使用的U盘,突然提示“未格式化”,里面的文件似乎都消失不见了。面对这种情况,很多人会感到…

35岁,程序员职业生涯的新起点

近年来,关于程序员职业生涯的讨论日益热烈,而“35岁被认为是程序员职业生涯的分水岭”更是成为了一个备受关注的话题。在这篇文章中,我们将探讨这一说法的合理性,并从事实和数据的角度来分析,为什么35岁并非程序员职业…

线程池-1:线程池是如何复用线程的?

这段代码实现了一个简单的线程池 SimpleThreadPool。主要包括以下几个关键部分: 构造函数:初始化最大线程数 maxPoolSize、任务队列 taskQueue、当前线程数 currentPoolSize,以及锁 lock 和条件 taskAvailable。 submit(Runnable task) 方法…

PSINS初学指导

2024-3-27/Evand/Ver1 因为惯导解算设计的数学公式很多,在编程时如果一步一步自己编,非常耗时耗力,所以在进行上层设计时,借助工具箱完成底层的复杂计算是很有必要的。另一方面,也能利用工具箱进行惯导解算方面的学习…

FPGA时钟资源详解(2)——Clock-Capable Inputs

FPGA时钟系列文章总览:FPGA原理与结构(14)——时钟资源https://ztzhang.blog.csdn.net/article/details/132307564 目录 一、概述 1.1 为什么使用CC 1.2 如何使用CC 二、Clock-Capable Inputs 2.1 SRCC 2.2 MRCC 2.3 其他用途 2.3.1…

WIFI驱动移植实验:WIFI驱动加载测试

一. 简介 前面文章学习了向kernel内核源码中添加 trl8188驱动代码,配置内核以支持 WIFI设备,使能WIFI功能。文章地址如下: WIFI驱动移植实验:删除Linux内核自带的 RTL8192CU 驱动-CSDN博客 WIFI驱动移植实验:将 rtl…

LeetCode 135. 分发糖果

n 个孩子站成一排。给你一个整数数组 ratings 表示每个孩子的评分。 你需要按照以下要求,给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果。相邻两个孩子评分更高的孩子会获得更多的糖果。 请你给每个孩子分发糖果,计算并返回需要准备的…

C语言中连字符“#”的使用,输出固件的编译时间和版本号

首先我们使用C语言宏定义和“#”来组合字符串 #define MAINVER 2#define SUBVER1 0#define SUBVER2 1#define STR(s) #s#define VERSION(a,b,c) "System V" STR(a) "." STR(b) "." STR(c) " "__DATE__ 然后我们在全局变量中定义一…

服务器硬件

目录 服务器CPU服务器GPU服务器内存服务器硬盘服务器主板散热系统(服务器风扇)服务器电源(电影供应器)其他网络适配器扩展卡 服务器CPU 基于架构的分类:根据CPU的架构不同,可以分为x86架构(如I…

API接口鉴权签名设计

在设计API接口的鉴权签名时,通常会使用一种加密算法来生成签名,以确保请求的合法性和安全性。以下是通过鉴权签名的设计方案。 1、接口秘钥设置 Key:123 Secret:abc 2、接口Url 接口Url需要使用https的协议保证接口数据安全传输 3、请求参数 3.1、…

VsCode的json文件不允许注释的解决办法

右下角找到注释点进去 输入Files: Associations搜索出此项 改为项为*.json值为jsonc保存即可 然后会发现VsCode的json文件就允许注释了