async/await 和promise.then 的执行时机

发布于 2022-09-07 12:16:25 字数 518 浏览 23 评论 0

例1
function  GenFunc () {
  new Promise(function(resolve) {
        resolve()
    }).then(function() {
        console.log('1')
    })
  console.log('2')
}
GenFunc()
// 执行结果
// 2
// 1
例2
async function  GenFunc () {
  new Promise(function(resolve) {
        resolve()
    }).then(function() {
        console.log('1')
    })
    await 'string';
    console.log('2')
}
GenFunc()
// 执行结果
// 1
// 2

请问为什么await会改变执行顺序。Promise.then属于microtasks。同步的代码没执行完是不会进入microtasks的。所以请问两段代码结果不一致的原因是什么

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

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

发布评论

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

评论(1

依 靠 2022-09-14 12:16:25

既然题主自己提到了microtask,我就假设题主已经知道例1是怎么回事了

async内的await会把之后的代码放入新的microtask,即使等待的东西实际上是同步的


详细解析:

(async function GenFunc() {
  new Promise(function constructPromise(resolve) { // 1. Promise构造器,同步执行constructPromise
    resolve()                                      // 2. resolve,将promiseCallback放入microtask队列位置1
  }).then(function promiseCallback() {
    console.log('1')                               // 6. microtask队列位置1
  })
  await 'string'                                   // 3. await,将之后的所有代码放入microtask队列位置2
  console.log('2')                                 // 7. microtask队列位置2
})()                                               // 4. async call return,返回Promise<pending>
console.log('3')                                   // 5. 执行剩余的同步代码
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文