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

宏任务与微任务:JavaScript异步编程的秘密

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

    • 摘要:
    • 引言:
    • 正文:
      • 1️⃣ 宏任务(Macrotask)
      • 2️⃣ 微任务(Microtask)
      • 3️⃣ 执行顺序
      • 4️⃣ 应用场景
    • 总结:
    • 参考资料:

摘要:

本文将详细介绍JavaScript中的宏任务和微任务的概念、执行顺序以及在异步编程中的应用,帮助您理解这一关键的异步处理机制。

引言:

🌐 在JavaScript中,事件循环是实现异步编程的核心。宏任务和微任务是事件循环中的两个重要概念,它们定义了异步代码的执行顺序。接下来,让我们一起来探索宏任务和微任务的魅力。

正文:

1️⃣ 宏任务(Macrotask)

宏任务(Macrotask)是 JavaScript 中的一个概念,它指的是那些需要较长时间才能完成的任务。宏任务通常在主线程上执行,可能会阻塞主线程的渲染。宏任务主要包括以下几种:

  1. script(整体代码)
  2. setTimeout
  3. setInterval
  4. I/O 操作(如读写文件、网络请求等)
  5. UI 渲染

宏任务与微任务(Microtask)相对应,微任务通常指的是那些可以快速完成的任务,例如处理一些数据、执行一些函数等。在 JavaScript 中,微任务主要通过 Promise、async/await 等语法实现。

宏任务与微任务的区分主要是根据任务的执行时间,宏任务通常需要较长时间才能完成,而微任务通常可以在较短的时间内完成。

在 JavaScript 引擎中,宏任务和微任务是分开执行的。当主线程空闲时,JavaScript 引擎会执行微任务;当有宏任务需要执行时,JavaScript 引擎会暂停微任务的执行,先执行宏任务。这样可以确保主线程的实时性,提高页面的响应速度。

宏任务主要包括:

  • 整体代码script(整体代码执行)
  • 渲染事件(如DOMContentLoaded)
  • 定时器(setTimeout、setInterval)
  • I/O(如读写文件、网络请求)
  • UI交互事件(如click、scroll)
  • 消息队列(如Web Workers)

2️⃣ 微任务(Microtask)

微任务(Microtask)是 JavaScript 中的一个概念,它指的是那些可以快速完成的任务。微任务通常在主线程上执行,不会阻塞主线程的渲染。微任务主要包括以下几种:

  1. Promise
  2. async/await
  3. MutationObserver
  4. IntersectionObserver

微任务与宏任务(Macrotask)相对应,宏任务通常指的是那些需要较长时间才能完成的任务,例如处理一些数据、执行一些函数等。在 JavaScript 中,宏任务主要通过 setTimeout、setInterval 等语法实现。

微任务与宏任务的区分主要是根据任务的执行时间,微任务通常需要较短的时间才能完成,而宏任务通常需要较长时间才能完成。

在 JavaScript 引擎中,微任务和宏任务是分开执行的。当主线程空闲时,JavaScript 引擎会执行微任务;当有宏任务需要执行时,JavaScript 引擎会暂停微任务的执行,先执行宏任务。这样可以确保主线程的实时性,提高页面的响应速度。

微任务主要包括:

  • Promise.then()
  • async/await
  • MutationObserver
  • Object.observe(已废弃)
  • 手动执行的微任务队列(如process.nextTick())

3️⃣ 执行顺序

在JavaScript中,事件循环按顺序执行宏任务和微任务。每个宏任务执行完毕后,会执行所有微任务,然后继续下一个宏任务,如此循环。这种机制确保了异步代码的有序执行。

4️⃣ 应用场景

宏任务和微任务在实际开发中有广泛应用,例如:

  • 实现轮播图、动画等需要与UI交互的功能。
  • 实现复杂的异步逻辑,如数据处理、网络请求等。
  • 优化页面性能,如使用微任务进行数据更新,避免重排和重绘。

总结:

🎉 宏任务和微任务是JavaScript异步编程的关键概念,它们定义了异步代码的执行顺序。通过了解宏任务和微任务的概念、执行顺序以及应用场景,我们可以更好地利用它们实现高效的异步编程。

参考资料:

  • 宏任务与微任务 百度百科
  • MDN Web Docs - JavaScript 事件循环
  • JavaScript宏任务与微任务解析

相关文章:

宏任务与微任务:JavaScript异步编程的秘密

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...

vant van-field 密码输入框小程序里隐藏、显示密码bug总结

老规矩先上效果图: vant 输入框组件 密码的隐藏与显示功能: 注: 用password属性控制密码的显示与隐藏 不要用type属性,type属性在真机上有时会没有效果 1、当然如果只用typepassword 不需要切换显示、隐藏也可以使用。 2、如果用到了密码的显示与…...

代理ip应用场景

代理IP是一种网络技术,它允许用户通过中间来访问互联网资源,隐藏真实的IP地址代理IP的应用场景非常泛,以下是一些常见的应用场景: 1 隐私保护:使用代理IP可以隐藏用户的真实IP地址,保护个人隐私。在浏览网…...

C/C++指针详解

接下来我们来介绍一下什么是指针? 指针其实就是元素存放地址,更加形象的比喻:在酒店中如果你想要去注必须去付费不然不能住,在计算机也同样如此(但是不需要付费哦)每当我们使用一个变量或其他需要申请空间…...

实验一:华为VRP系统的基本操作

1.1实验介绍 1.1.1关于本实验 本实验通过配置华为设备,了解并熟悉华为VRP系统的基本操作 1.1.2实验目的 理解命令行视图的含义以及进入离开命令行视图的方法 掌握一些常见的命令 掌握命令行在线帮助的方法 掌握如何撤销命令 掌握如何使用命令快捷键 1.1.3实验组网 …...

ChatGPT发不出消息?GPT发不出消息怎么办?

前言 今天发现,很多人的ChatGPT无法发送信息,我就登陆看一下自己的GPT的情况,结果还真的无法发送消息,ChatGPT 无法发送消息,但是能查看历史的对话,不过通过下面的方法解决了。 第一时间先打开官方的网站&a…...

【论文笔记】Language Models are Few-Shot Learners

Language Models are Few-Shot Learners 回顾一下第一代 GPT-1 : 设计思路是 “海量无标记文本进行无监督预训练少量有标签文本有监督微调” 范式;模型架构是基于 Transformer 的叠加解码器(掩码自注意力机制、残差、Layernorm)&a…...

解决:Glide 在回调中再次加载图片报错

一、问题说明 Glide 加载图片时监听了回调&#xff0c;并在失败时再次加载其它图片后报错。 代码&#xff1a; Glide.with(mContext).load(imgTeacher).listener(new RequestListener<Drawable>() {Overridepublic boolean onLoadFailed(Nullable GlideException e, O…...

Java学习笔记之IDEA的安装与下载以及相关配置

1 IDEA概述 ​IDEA全称IntelliJ IDEA&#xff0c;是用于Java语言开发的集成环境&#xff0c;它是业界公认的目前用于Java程序开发最好的工具。 集成环境&#xff1a; ​把代码编写&#xff0c;编译&#xff0c;执行&#xff0c;调试等多种功能综合到一起的开发工具。 2 IDEA…...

【共享内存】System V共享内存{通信原理/相关接口/代码测试}

文章目录 1.初识共享内存1.0浅谈System V1.1什么是共享内存&#xff1f;1.2Linux-System V共享内存1.3图解共享内存1.4对共享内存的理解 2.创建共享内存2.1共享内存如何创建&#xff1f;2.2代码运行与测试2.3shm与pipe的区别2.4shm缺乏访问控制 3.代码理解shm3.1Log.hpp3.2comm…...

Web渗透测试流程

什么是渗透测试 渗透测试 (penetration test),是通过模拟恶意黑客的攻击方法&#xff0c;来评估计算机网络系统安全的一种评估方法。这个过程包括对系统的任何弱点、技术缺陷或漏洞的主动分析&#xff0c;这个分析是从一个攻击者可能存在的位置来进行的&#xff0c;并且从这个…...

探索机器学习的无限可能性:从初学者到专家的旅程

探索机器学习的无限可能性&#xff1a;从初学者到专家的旅程 在当今数字时代&#xff0c;机器学习无疑是最引人注目的技术之一。它已经深入到我们生活的方方面面&#xff0c;从个性化推荐到自动驾驶汽车&#xff0c;再到医疗诊断和金融预测。但是&#xff0c;即使我们已经见证…...

【python】六个常见爬虫案例【附源码】

大家好&#xff0c;我是博主英杰&#xff0c;整理了几个常见的爬虫案例&#xff0c;分享给大家&#xff0c;适合小白学习 一、爬取豆瓣电影排行榜Top250存储到Excel文件 近年来&#xff0c;Python在数据爬取和处理方面的应用越来越广泛。本文将介绍一个基于Python的爬虫程序&a…...

Java零基础-多维数组

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一个人虽可以走的更快&#xff0c;但一群人可以走的更远。 我是一名后…...

Linux网络套接字之UDP网络程序

(&#xff61;&#xff65;∀&#xff65;)&#xff89;&#xff9e;嗨&#xff01;你好这里是ky233的主页&#xff1a;这里是ky233的主页&#xff0c;欢迎光临~https://blog.csdn.net/ky233?typeblog 点个关注不迷路⌯▾⌯ 实现一个简单的对话发消息的功能&#xff01; 目录…...

Apache POI 解析和处理Excel

摘要&#xff1a;由于开发需要批量导入Excel中的数据&#xff0c;使用了Apache POI库&#xff0c;记录下使用过程 1. 背景 Java 中操作 Excel 文件的库常用的有Apache POI 和阿里巴巴的 EasyExcel 。Apache POI 是一个功能比较全面的 Java 库&#xff0c;适合处理复杂的 Offi…...

SQL 注入攻击 - insert注入

环境准备:构建完善的安全渗透测试环境:推荐工具、资源和下载链接_渗透测试靶机下载-CSDN博客 一、注入原理 描述:insert注入是指通过前端注册的信息被后台通过insert操作插入到数据库中。如果后台没有做相应的处理,就可能导致insert注入漏洞。原因:后台未对用户输入进行充…...

第一个 Angular 项目 - 添加路由

第一个 Angular 项目 - 添加路由 前置项目是 第一个 Angular 项目 - 添加服务&#xff0c;之前的切换页面使用的是 ngIf 对渲染的组件进行判断&#xff0c;从而完成渲染。这一步的打算是添加路由&#xff0c;同时添加 edit recipe 的功能(同样通过路由实现) 用到的内容为&…...

如何简洁高效的搭建一个SpringCloud2023的maven工程

前言 依赖管理有gradle和maven&#xff0c;在这里选择比较常用和方便的Maven作为工程项目和依赖管理工具来搭建SpringCloud实战工程。主要用到的maven管理方式是多模块和bom依赖管理。 什么是maven的多模块依赖管理 Maven 多模块项目相对于单模块项目而言&#xff0c;依赖是…...

uniapp直接连接wifi(含有ios和安卓的注意事项)

前言 小程序中直接连接wifi-----微信小程序 代码 启动 //启动wifistartWifi() {return new Promise((resolve, reject) > {uni.startWifi({success: (res) > {console.log(启动wifi 成功, res)resolve(true)},fail: (err) > {console.error(启动wifi 失败, err)uni.s…...

无显示器环境下树莓派系统安装与网络配置全攻略(SSH+USB共享网络)

1. 无显示器环境下的树莓派系统安装准备 当你手头有一块树莓派开发板&#xff0c;却没有显示器、键盘鼠标这些外设时&#xff0c;系统安装和初始配置可能会让你感到无从下手。别担心&#xff0c;这正是本文要解决的核心问题。我曾在多个项目中遇到这种情况&#xff0c;摸索出一…...

探索前沿技术趋势:2023年最值得关注的五大创新领域

1. 人工智能&#xff1a;从大模型到智能体的进化 2023年的人工智能领域正在经历一场范式转移。如果说前几年我们还在讨论单个模型的性能提升&#xff0c;现在整个行业已经转向多模态大模型和自主智能体的实战落地。我最近测试了几个主流开源模型&#xff0c;发现它们的推理能力…...

三步搞定Windows多语言软件兼容性:Locale Emulator终极指南

三步搞定Windows多语言软件兼容性&#xff1a;Locale Emulator终极指南 【免费下载链接】Locale-Emulator Yet Another System Region and Language Simulator 项目地址: https://gitcode.com/gh_mirrors/lo/Locale-Emulator 你是否曾经遇到过这样的烦恼&#xff1f;下载…...

从DS3231到RX8025T:手把手教你为Arduino点阵时钟更换低成本高精度RTC模块

从DS3231到RX8025T&#xff1a;低成本高精度RTC模块的完整迁移指南 1. 为什么选择RX8025T替代DS3231 在电子创客项目中&#xff0c;实时时钟模块&#xff08;RTC&#xff09;的选择往往需要在精度、成本和功能之间寻找平衡点。DS3231以其出色的精度&#xff08;2ppm&#xff…...

Xamarin开发者必看:用CommunityToolkit.Mvvm简化跨平台移动开发(支持iOS/Android全版本)

Xamarin开发者必看&#xff1a;用CommunityToolkit.Mvvm简化跨平台移动开发&#xff08;支持iOS/Android全版本&#xff09; 在跨平台移动开发领域&#xff0c;Xamarin一直以其原生性能和代码共享优势占据重要地位。然而&#xff0c;随着项目规模扩大&#xff0c;传统的MVVM实现…...

智能项目员中的进度控制与资源协调

智能项目员中的进度控制与资源协调 在当今快速发展的数字化时代&#xff0c;智能项目员已成为企业项目管理中不可或缺的角色。他们不仅需要掌握传统项目管理的核心技能&#xff0c;还需借助智能化工具实现高效的进度控制与资源协调。如何通过技术手段优化项目流程、避免资源浪…...

G-Helper:华硕笔记本性能调校的轻量级神器,释放硬件潜能

G-Helper&#xff1a;华硕笔记本性能调校的轻量级神器&#xff0c;释放硬件潜能 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, T…...

毫秒级响应!NEURAL MASK幻镜RMBG-2.0模型部署与推理加速教程

毫秒级响应&#xff01;NEURAL MASK幻镜RMBG-2.0模型部署与推理加速教程 1. 为什么你需要一个更好的抠图工具&#xff1f; 如果你曾经尝试过给照片换背景&#xff0c;尤其是处理带发丝的人像、半透明的婚纱或者边缘复杂的物体&#xff0c;你大概率会感到头疼。传统的抠图工具…...

oidc-client-js 实战案例:基于 VanillaJS 的完整认证流程实现

oidc-client-js 实战案例&#xff1a;基于 VanillaJS 的完整认证流程实现 【免费下载链接】oidc-client-js OpenID Connect (OIDC) and OAuth2 protocol support for browser-based JavaScript applications 项目地址: https://gitcode.com/gh_mirrors/oi/oidc-client-js …...

Coze (扣子) 开发AI智能体

Coze (扣子) 已经成为连接底层大模型与实际业务场景的核心“零代码/低代码”平台。利用 Coze 开发一个英语学习 AI 智能体&#xff08;Agent&#xff09;&#xff0c;本质上是将各种原子能力&#xff08;插件、工作流、记忆&#xff09;组装进一个“大脑”中。以下是开发一个高…...