宏任务和微任务

事件循环概述

事件循环(Event Loop)是JavaScript 引擎用来处理异步任务的一种机制,主要由主线程任务队列组成。

js代码可分为同步任务异步任务同步任务主线程 顺序执行,而异步任务由异步进程处理后将回调函数放入任务队列,等待主线程读取调用。

主线程执行完当前的同步任务后,不断读取调用任务队列的回调函数,直到清空任务队列,该循环机制称为事件循环

宏任务和微任务

异步任务分为 宏任务(Macro task)微任务(micro task)

宏任务 (Macrotask) 微任务 (Microtask)
script(整体代码块) Promise.then/catch/finally
setTimeout async await
setInterval queueMicrotask
setImmditate MutationObserver(监听器)
I/O,事件队列 process.nextTick
requestAnimationFrame(争议)

宏任务:代表着 JavaScript 运行时环境中的一个主要工作单元,类似一个载体。

微任务 :运行依托于宏任务,执行优先级高于同轮次的宏任务。

代码执行过程如下:

  1. 进入宏任务
  2. 执行所有同步代码,将异步任务放入对应的任务队列
  3. 执行微任务队列中的回调函数
  4. 从宏任务队列中取出下一个宏任务
  5. 重复上述步骤

举个栗子

javascript 复制代码
async function test() {
    await console.log(8);
    console.log(9);
}

console.log(1);

test();

setTimeout(() => {
    console.log(2);
}, 0);

new Promise((resolve) => {
    console.log(4);
    resolve();
    console.log(5);
}).then(() => {
    console.log(6);
});

console.log(7);

执行顺序:

1--> 8--> 4--> 5--> 7--> 9--> 6--> 2


再举个栗子

javascript 复制代码
async function test() {
    await console.log(1);
    console.log(2);
}

console.log(3);

test();

setTimeout(() => {
	console.log(4);
}, 0);

new Promise((resolve) => {
    console.log(5);
    resolve();
}).then(async () => {
    await console.log(6);
    console.log(7);
}).then(() => {
    console.log(8);
});

new Promise((resolve) => {
    console.log(9);
    resolve();
}).then(() => {
    console.log(10);
    setTimeout(() => {
        console.log(11);
    });
}).then(() => {
    console.log(12);
});

执行顺序:

3--> 1--> 5--> 9--> 2--> 6--> 10--> 7--> 12--> 8--> 4--> 11

相关推荐
老华带你飞16 分钟前
公寓管理系统|SprinBoot+vue夕阳红公寓管理系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·课程设计
小飞猪Jay17 分钟前
面试速通宝典——10
linux·服务器·c++·面试
qbbmnnnnnn1 小时前
【WebGis开发 - Cesium】如何确保Cesium场景加载完毕
前端·javascript·vue.js·gis·cesium·webgis·三维可视化开发
数据分析螺丝钉1 小时前
力扣第240题“搜索二维矩阵 II”
经验分享·python·算法·leetcode·面试
无理 Java1 小时前
【技术详解】SpringMVC框架全面解析:从入门到精通(SpringMVC)
java·后端·spring·面试·mvc·框架·springmvc
f8979070702 小时前
layui动态表格出现 横竖间隔线
前端·javascript·layui
鱼跃鹰飞2 小时前
Leecode热题100-295.数据流中的中位数
java·服务器·开发语言·前端·算法·leetcode·面试
TANGLONG2222 小时前
【C语言】数据在内存中的存储(万字解析)
java·c语言·c++·python·考研·面试·蓝桥杯
二十雨辰2 小时前
[uni-app]小兔鲜-04推荐+分类+详情
前端·javascript·uni-app
霸王蟹3 小时前
Vue3 项目中为啥不需要根标签了?
前端·javascript·vue.js·笔记·学习