下面这段async异步代码的执行顺序有些不理解,求大神能指导指导,最好能帮忙分析下相关微任务队列的过程
async function async1 () {
return new Promise(resolve => {
Promise.resolve().then(() => {
async2().then(resolve)
})
}).then(() => {
console.log('async1 end')
})
}
async function async2 () {}
async1()
Promise.resolve()
.then(function () {
console.log('promise2')
})
.then(function () {
console.log('promise3')
})
.then(function () {
console.log('promise4')
})
//promise2
//promise3
//async1 end
//promise4
执行 console.log('promise4') 之前
会经历两轮微任务的执行, 因为你每次调用 .then都是一次新的微任务,
浏览器会去跑上一个队列里面的微任务
你数一数 async1 里面要'耽误'两次, 才能执行到 end