async/await、Promise、setTimeout 执行顺序,js宏任务微任务的运行机制

文章详细阐述了JavaScript的事件循环机制,包括宏任务和微任务的执行顺序。在每个tick中,先执行一个宏任务,期间产生的微任务会被推入微任务队列。宏任务执行完毕后,会立即处理微任务队列。此过程涉及到setTimeout、Promise、async/await等关键概念。
摘要由CSDN通过智能技术生成

在事件循环中,每进行一次循环操作称为 tick,每一次 tick 的任务处理模型是比较复杂的,但关键步骤如下:

  • 执行一个宏任务(栈中没有就从事件队列中获取)
  • 执行过程中如果遇到微任务,就将它添加到微任务的任务队列中
  • 宏任务执行完毕后,立即执行当前微任务队列中的所有微任务(依次执行)
  • 当前宏任务执行完毕,开始检查渲染,然后GUI线程接管渲染
  • 渲染完毕后,JS线程继续接管,开始下一个宏任务(从事件队列中获取)
    流程图如下:
    在这里插入图片描述

宏任务包含: script(整体代码)、setTimeout、setInterval、I/O、UI交互事件、postMessage、MessageChannel、setImmediate(Node.js 环境)

微任务包含: Promise.then、MutaionObserver、process.nextTick(Node.js 环境)
由于因为async await 本身就是promise+generator的语法糖。所以await后面的代码是microtask。

要注意:
对于如下代码

async function async1() {
	console.log('async1 start');
	await async2();
	console.log('async1 end');
}

等价于

async function async1() {
	console.log('async1 start');
	Promise.resolve(async2()).then(() => {
                console.log('async1 end');
        })
}

参考文章: 事件队列执行顺序
个人总结: 同步任务按顺序执行完 -> 微任务再按顺序执行完 -> 最后宏任务再按顺序执行完;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

#老程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值