| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> 10道 Promise 面试题彻底理解 Promise 异步执行顺序 -> 正文阅读 |
|
[JavaScript知识库]10道 Promise 面试题彻底理解 Promise 异步执行顺序 |
前言上一篇文章详细说明了关于 Promise 的概念以及执行顺序,Promise 作为 JavaScript 中的关键特性,无论是在日常工作中还是面试中,我们都必须掌握它。 前段时间在网上看到了一些关于 Promise 的面试题,质量很好,在这里整理到下面,并加上我一些自己的见解,欢迎斧正! 1. 同步代码块
第一个面试题可谓是非常简单了,
所以这段代码依次输出结果为 1 3 2 2. 出现异步代码
在这部分代码中,出现了一段异步代码:也就是 .then() 中的回调函数 要记住一个原则:同步先行,异步靠后,Javascript 引擎总是先执行同步代码,然后在执行异步代码。 此时,我们只需要区分同步代码和异步代码即可。 所以这段代码吗输出结果为: start 1 end 2 3. 有 resolve 的地方
这段代码与前面的代码基本一致,唯一区别是在 resolve() 之后有一个 console.log() 要记住:resolve 方法不会中断函数的执行,它背后的代码仍然会继续执行。 所以输出的结果是: start 1 3 end 2 4. 不被调用 resolve 的地方
在这段代码中,resolve 方法从未被调用过,因此 p始终处于挂起状态 。 所以 p.then(…) 从未被执行过,故不会在控制台中打印。 所以输出的结果是: start 1 end 5. 带有函数的
这段代码部分人开起来可能会有些迷惑,因为加了一层 fn 但我们要要记住,无论有多少层函数调用,我们的基本原则都是一样的:
输出结果为 start 3 1 end 2 详细解析:
6. Fulfilling Promise
输出结果为: start end 1 2 详细解析:
7. 宏任务 微任务
详细解析: 这段代码相比较上一个来说,多了一个定时器,我们知道,定时器也是一个异步操作。那么这时候问题就来了,同步代码是按照调用顺序执行的,那么异步回调函数时按照什么顺序执行的呢?大家可以参考下我的上一篇博客:Promise原理解析及执行顺序。 在上面的代码中,setTimeout的定时器是0秒,Promise.resolve() 也会在执行后立即返回一个已完成的 Promise 对象。 两个异步任务都是立即完成的,那么谁的回调函数会先执行呢? 有人会说 setTimeout 在前面,所以先打印 setTimeout,然后打印 resolve,实际上,当我们在控制台运行下代码时会发现,实际情况并不是我们想的那样。 它们是有优先级的。 微任务 > 宏任务
虽然 setTimeout 和 Promise.resolve() 是同时完成的,甚至 setTimeout 的代码写在前面,但是由于它的优先级较低,所以它的回调函数是在后面执行的。 所以输出结果是:start end resolve success 8. 微任务 + 宏任务 升级
详细解析: 首先执行同步代码: 1 2 end 然后找到 微任务 和 宏任务 从上一个代码解析中我们知道,定时器是宏任务,Promise 是微任务: 但这里有一个陷阱: 当前的promise 还处于 pending 状态,所以promise.then() 这部分代码(微任务)暂时不会被执行。 所以会先执行定时器中的回调函数,然后在执行微任务。 所以输出结果为: 1 2 end timerStart timerEnd resolve 9. 微任务 宏任务 交替执行排序
输出结果为: timer1 promise1 tiemr2 详细解析: 关于 宏任务 和 微任务,正确的理解是:
在上面代码中,没有和宏任务同步的微任务,所以开始执行 timer1 这个宏任务; 在 timer1 的宏任务中,新增了一个微任务,且该promise 对象的状态已经变为 fufilled(已成功),所以Promise.then() 的回调函数会在第二个宏任务 setTimeout 的回调函数之前执行。 所以执行结果为: timer1 promise1 tiemr2 10 最终升级版
如果能够正确写出答案且能说明原因的话,说明你对 Promise 的理解已经很强了,面试基本上没有问题。 详细解析: 按照以下思路进行思考:
① 执行所有同步代码: 打印 start end ② 执行所有微任务 在这里打印 promise1 ③ 执行第一个宏任务 在这里打印 timer1 注意:在这一步中,宏任务将一个新的为任务添加到任务队列中 ④ 执行所有新添加的微任务
⑤ 执行下一个宏任务
结论在面试中,如果有类似的面试题,只需要记住一下三个核心要点,问题即可迎刃而解。
|
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/11 16:01:25- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |