async输出顺序的一道前端面试题疑问

发布于 2022-09-13 00:15:16 字数 770 浏览 24 评论 0

async function async1() {
      console.log('async1 start');
      await async2();
      console.log('async1 end');
    }
    
    async function async2() {
      console.log('async2 start');
      return new Promise((resolve, reject) => {
        resolve();
        console.log('async2 promise');
      })
    }

    async1();
    
    new Promise(function(resolve) {
      console.log('promise1');
      resolve();
    }).then(function() {
      console.log('promise2');
    }).then(function() {
      console.log('promise3');
    });

为什么输出顺序如下

async1 start
async2 start
async2 promise
promise1
promise2
promise3
async1 end

主要困惑是 async1 end 为什么在 promise3 后面?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

吹泡泡o 2022-09-20 00:15:16

async1函数可以转化成下面这样

async function async1() {
    console.log('async1 start');
    console.log('async2 start');
    new Promise((resolve, reject) => {
        const thenable = new Promise((resolve2, reject2) => {
            resolve2();
            console.log('async2 promise');
        })
        new Promise((res, rej) => {
            thenable.then().then(resolve)
        })
    }).then(() => {
        console.log('async1 end');
    })
}

具体的分析这里有:https://segmentfault.com/q/10...

无可置疑 2022-09-20 00:15:16

问题的关键在

async function async2() {
  console.log('async2 start')
  return new Promise((resolve, reject) => {
    resolve()
    console.log('async2 promise')
  })
}

可以用 Promise 做如下转换

async function async2() {
  console.log('async2 start')
  return new Promise((resolve, reject) => {
    resolve()
    console.log('async2 promise')
  })
}
// ->
function async2() {
  console.log('async2 start')
  const p = new Promise((resolve, reject) => {
    resolve()
    console.log('async2 promise')
  })
  return new Promise(function (resolve, reject) {
    Promise.resolve().then(() => {
      p.then(resolve)
    })
  })
}

更详细解释,可以看我的文章Async Function 背后的秘密

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文