setTimeout与异步Promise执行顺序问题

执行顺序问题

首先需要区分宏任务与微任务:

​ 宏任务:同步任务,I/O(比如读写文件),setTimeout(),setInterval(),requestAnimationFrame()等

​ 微任务:Promise.then/catch/finally,generator,async / await,MutationObserver等

在某一个宏任务执行完毕后,会先查看微任务事件队列当中是否有任务,有就执行微任务,然后才是宏队列。

比如下面的例子,这也是一道面试题,让你说出执行顺序。

    setTimeout(function() {
      console.log(1)
    }, 0);
    new Promise(function executor(resolve) {
      console.log(2);
      for( var i=0 ; i<10000 ; i++ ) {
        i == 9999 && resolve();
      }
      console.log(3);
    }).then(function() {
      console.log(4);
    });
    console.log(5);

这样一堆确实很懵逼,毕竟自己也不会…

解答:

​ 首先,setTimeout是一个宏任务,扔到了异步宏任务队列当中。代码向下执行

​ 其次遇到 new Promise() 当中的传入一个函数function executor是一个函数所以会立即执行,===> 2

​ 继续向下执行遇到 for 循环,不管他执行多少次,i= 9999的时候,执行resolve(),此时将 then 放到了异步微任务队列当中

​ 向下执行遇到console.log(3) ====> 3

​ 因为同步任务还未走完,继续向下执行console.log(5) , ====> 5

​ 当同步的宏任务执行完毕后,会先查看微任务队列当中有无需要执行的,此时之前扔进去的resolve(),也就是then,这个时候就会执行 console.log(4) ====> 4

​ 然后微任务队列执行完毕后,再去执行宏任务队列。此时setTimeout()才会执行 ====> 1

如下图结果所示:

结果所示:(至于undefinied,语句执行完成后一般都会有这个)
例如:
在这里插入图片描述

在这里插入图片描述

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
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 关于setTimeoutPromise执行顺序问题](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 ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值