问答题859/1593【Promise第24题】下面代码的输出是什么?

1function promise1 () { 2 let p = new Promise((resolve) => { 3 console.log('promise1'); 4 resolve('1') 5 }) 6 return p; 7} 8function promise2 () { 9 return new Promise((resolve, reject) => { 10 reject('error') 11 }) 12} 13promise1() 14 .then(res => console.log(res)) 15 .catch(err => console.log(err)) 16 .finally(() => console.log('finally1')) 17 18promise2() 19 .then(res => console.log(res)) 20 .catch(err => console.log(err)) 21 .finally(() => console.log('finally2')) 22
难度:
2022-01-09 创建

参考答案:

执行过程

  • 首先定义了两个函数promise1promise2,先不管接着往下看。
  • promise1函数先被调用了,然后执行里面new Promise的同步代码打印出promise1
  • 之后遇到了resolve(1),将p的状态改为了resolved并将结果保存下来。
  • 此时promise1内的函数内容已经执行完了,跳出该函数
  • 碰到了promise1().then(),由于promise1的状态已经发生了改变且为resolved。因此将·promise1().then()·这条微任务加入本轮的微任务列表(这是第一个微任务)
  • 这时候要注意了,代码并不会接着往链式调用的下面走,也就是不会先将.finally加入微任务列表,那是因为.then本身就是一个微任务,它链式后面的内容必须得等当前这个微任务执行完才会执行,因此这里我们先不管.finally()
  • 再往下走碰到了promise2()函数,其中返回的new Promise中并没有同步代码需要执行,所以执行reject('error')的时候将promise2函数中的Promise的状态变为了rejected
  • 跳出promise2函数,遇到了promise2().catch(),将其加入当前的微任务队列(这是第二个微任务),且链式调用后面的内容得等该任务执行完后才执行,和.then()一样。
  • 本轮的宏任务全部执行完了,来看看微任务列表,存在promise1().then(),执行它,打印出1,然后遇到了.finally()这个微任务将它加入微任务列表(这是第三个微任务)等待执行
  • 再执行promise2().catch()打印出error,执行完后将finally2加入微任务加入微任务列表(这是第四个微任务)
  • 本轮又全部执行完了,但是微任务列表还有两个新的微任务没有执行完,因此依次执行finally1finally2

结果

'promise1'
'1'
'error'
'finally1'
'finally2'

最近更新时间:2024-07-20

赞赏支持

预览

题库维护不易,您的支持就是我们最大的动力!