关于面试中异步与延时 执行顺序的预期结果问题

Posted wenqiangit

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于面试中异步与延时 执行顺序的预期结果问题相关的知识,希望对你有一定的参考价值。

  1. 理解同步与异步的概念(看第一个图)

  2. 宏任务与微任务,简单说主线程上的最外层代码块就是宏任务(包括Promise和setTimeout),

     如果最外层代码块是异步任务,那么它内部的任务就是微任务
  3. 宏任务与微任务相当于主线程和子线程的关系,但是可以理解为js中只有一个主线程和一个子线程

技术分享图片

技术分享图片

// 主线程的宏任务
setTimeout(() => {
    // 子线程的宏任务
    new Promise((resolve, reject) => {
        console.log(1);
        resolve();
    }).then(() => {
        // 子线程的微任务
        console.log(2)
    });

    // 子线程的宏任务
    console.log(3);

    // 子线程的宏任务
    setTimeout(() => {

        // 子线程的微任务
        console.log(4)
    }, 1000)

}, 1000);

// 主线程的宏任务
console.log(5);


所以 预期结果是 5>1>3>2>4

以上是关于关于面试中异步与延时 执行顺序的预期结果问题的主要内容,如果未能解决你的问题,请参考以下文章

由一道bilibili面试题看Promise异步执行机制

Java中如何保证线程顺序执行

promise执行顺序

通过节点的异步/等待不需要按预期顺序返回结果 - 使用啥正确模式?

js执行顺序+同步异步

js同步异步执行顺序setTimeOut面试题分析