关于javascript:Day-91100-JS中宏任务setTimeout和微任务async-await的执行顺序的demo

(一)题目

async function async1() {
  console.log('async1 start')
  await async2()
  console.log('async1 end')
  setTimeout(() => { console.log('time1') }, 0)
}
async function async2() {
  console.log('async2 start')
  setTimeout(() => { console.log('time2') }, 0)
}
async1()
console.log('start')
setTimeout(() => { console.log('time3') }, 0)

(二)打印程序

async1 start
async2 start
start
async1 end
time2
time3
time1

(三)剖析

1、遇到await前面以后行的内容(无论语句还是函数办法);
2、遇到await前面非以后行的内容,是在函数执行后,才执行的;
3、宏工作队列中会依照push进去的先后顺序,顺次打印输出;

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理