JavaScript--Promise执行顺序

代码

    <script>
      console.log(1)
      const p = new Promise((resolve) => {
        console.log(2)
        resolve()
      })
      console.log(3)
      setTimeout(() => {
        console.log(4)
      }, 0)
      p.then(() => console.log(5))
      setTimeout(() => {
        console.log(6)
      }, 0)
      console.log(7)
    </script>

输出结果

在这里插入图片描述

分析

正常顺序执行 -> then -> setTimeouts -> then中 setTimeouts
正常顺序执行:输出1 2 3 7;
then:输出5;
setTimeouts :输出4 6。

拓展

参考:js 宏任务和微任务

//主线程直接执行
console.log('1');
//丢到宏事件队列中
setTimeout(function() {
    console.log('2');
    process.nextTick(function() {
        console.log('3');
    })
    new Promise(function(resolve) {
        console.log('4');
        resolve();
    }).then(function() {
        console.log('5')
    })
})
//微事件1
process.nextTick(function() {
    console.log('6');
})
//主线程直接执行
new Promise(function(resolve) {
    console.log('7');
    resolve();
}).then(function() {
    //微事件2
    console.log('8')
})
//丢到宏事件队列中
setTimeout(function() {
    console.log('9');
    process.nextTick(function() {
        console.log('10');
    })
    new Promise(function(resolve) {
        console.log('11');
        resolve();
    }).then(function() {
        console.log('12')
    })
})

输出结果

1->7->6->8->2->4->3->5->9->11->10->12

分析

首先,JavaScript 是单线程执行的,无法同时执行多段代码。当某一段代码正在执行的时候,所有后续的任务都必须等待,形成一个任务队列。一旦当前任务执行完毕,再从队列中取出下一个任务,这也常被称为 “阻塞式执行”。

具体执行过程

首先 JavaScript 引擎会执行一个宏任务,注意这个宏任务一般是指主干代码本身,也就是目前的同步代码执行过程中如果遇到微任务,就把它添加到微任务任务队列中宏任务执行完成后,立即执行当前微任务队列中的微任务,直到微任务队列被清空。微任务执行完成后,开始执行下一个宏任务。如此循环往复,直到宏任务和微任务被清空。

宏任务:主代码块、setTimeout、setInterval、DOM事件、AJAX请求。
微任务:Promise、async/await、process.nextTick。

主代码块作为宏任务最先运行:输出1,7;
setTimeout分发到宏任务事件队列Event Queue中;
process.nextTick,Promise.then分发到微任务事件队列Event Queue中;
此时,主代码块执行完毕,即第一个宏任务执行完毕,开始执行微任务,输出 6,8;
第一个微任务执行完毕,开始执行第二个宏任务setTimeout,遵循先执行主线程宏任务,再执行微任务process.nextTick,输出2,4,3,5;
开始执行第三个宏任务setTimeout,遵循先执行主线程宏任务,再执行微任务,输出9,11,10,12。

总结

1、微任务是在宏任务的执行中产生的,所以一开始程序执行时是没有微任务的。
2、系统将微任务执行完以后,才会去执行下一个宏任务。
3、宏任务里如果有宏任务,不会执行里面的那个宏任务,而是被丢进任务队列后面,所以会最后执行。
4、宿主环境提供的属于宏任务:例如setTimeout。由语言标准提供的属于微任务:例如promise.then。可以以此来区分宏任务和微任务。

参考:https://blog.csdn.net/ZHANGYANG_1109/article/details/123839466

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中,setInterval和Promise执行顺序是根据事件循环机制来确定的。事件循环是JavaScript用来处理异步操作的一种机制。首先,让我们来了解一下事件循环的基本原理。 JavaScript是单线程执行的,意味着同时只能执行一段代码。当某一段代码正在执行时,其他任务必须等待。这种执行方式也被称为"阻塞式执行"。JavaScript中的任务队列用于存储等待执行的任务。一旦当前任务执行完毕,事件循环会从任务队列中取出下一个任务并执行。 对于setInterval和Promise执行顺序问题,具体的执行顺序取决于它们被添加到任务队列的时间和优先级。根据引用的说明,事件循环的优先级从高到低依次是:主代码块 > setImmediate > MessageChannel > setTimeout / setInterval。 如果存在多个setInterval和Promise任务,它们会根据优先级和添加到任务队列的顺序依次执行。setInterval的任务会按照指定的时间间隔重复执行,而Promise的任务则会在其他任务执行完毕后被执行。 需要注意的是,Promise中的then方法是异步执行的,它会在当前任务执行完毕后被添加到任务队列中,等待执行。因此,即使是在Promise的then方法中使用了setTimeout,它也会按照任务队列的顺序被执行。具体的执行顺序可能因为任务队列中的任务数量和优先级而有所不同。 综上所述,setInterval和Promise执行顺序是根据它们被添加到任务队列的时间和优先级来确定的。具体的执行顺序可以通过事件循环机制来理解。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [js 关于setTimeout和Promise执行顺序问题](https://blog.csdn.net/zlzbt/article/details/100577954)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JavaScript--Promise执行顺序](https://blog.csdn.net/qq_45633813/article/details/126781947)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值