Promise面试题

Promise面试题,带你搞懂同步异步执行顺序

  • 前置知识
  • 面试题
    • 面试题一
    • 面试题二
    • 面试题三
    • 面试题四
  • 分析
    • 面试题一分析
    • 面试题二分析
    • 面试题三分析
    • 面试题四分析



在这里插入图片描述

前置知识

Promise中的then方法
then:指定用于得到成功value的成功回调和用于得到失败reason的失败回调,并且将放回一个新的Promise实例化对象
成功的状态:执行then方法的第一个回调函数 失败的状态:执行then方法的第二个回调函数

then方法的返回值是Promise实例化对象,其状态取决于回调函数的内容

  • 如果返回的为非Promise实例化对象,则得到一个成功的Promise
  • 如果返回的是Promise实例化对象,则Promise实例化对象的状态和结果值将直接影响result常量的状态和结果值
  • 如果为抛出异常,则新的Promise实例化对象(result)为失败的Promise

JS中用来存储待执行回调函数的队列中包含了两个特定的队列
宏队列:用来保存执行的宏任务(回调),比如:定时器、DOM时间操作,ajax操作
微队列:用来保存执行的微任务(回调),比如:promise(then catch finally)
JS执行的时候会区分两个队列

  1. 首先JS引擎会先将所有的同步代码都执行完
  2. 接着在每次准备取出第一个宏任务的执行之前,都需要将所有的微任务一个一个取出来执行
  • 顺序为:同步任务<–微任务<–宏任务

在这里插入图片描述

事件循环的执行顺序可以概括为以下几个步骤(以下答案来自ChatGPT):

  1. 执行同步任务(同步代码),直到执行栈为空。
  2. 执行微任务队列中的所有微任务。微任务包括Promise的回调函数、MutationObserver的回调函数等。
  3. 更新渲染(如果需要)。
  4. 执行下一个宏任务。
    在上述步骤中,微任务队列的执行在渲染之前,也在下一个宏任务之前。这意味着微任务具有更高的优先级,可以在下一个宏任务之前立即执行。

面试题

面试题一

etTimeout(()=>{console.log(1);},0)Promise.resolve().then(()=>{console.log(2);})Promise.resolve().then(()=>{console.log(3);})console.log(4);//答案:... 

面试题二

setTimeout(()=>{console.log(1);
})
new Promise(resolve=>{console.log(2);resolve()
}).then(()=>{console.log(3);
}).then(()=>{console.log(4);
})
console.log(5);
//答案:...

面试题三

const first = () => (new Promise((resolve,reject)=>{console.log(1);let p = new Promise((resolve,reject)=>{console.log(2);setTimeout(()=>{console.log(3);resolve(4)},0)resolve(5)})resolve(6)p.then(arg=>{console.log(arg);})
}))
first().then(arg=>{console.log(arg);
})
console.log(7);
//答案:...

面试题四

在这里插入图片描述

setTimeout(()=>{console.log(0);},0)new Promise((resolve,reject)=>{console.log(1);resolve();}).then(()=>{  //片段一console.log(2);new Promise((resolve,reject)=>{console.log(3);resolve();}).then(()=>{console.log(4);}).then(()=>{console.log(5);})}).then(()=>{  // 片段二console.log(6);})new Promise((resolve,reject)=>{console.log(7);resolve();}).then(()=>{  // 片段三console.log(8);})//答案:...

分析

面试题一分析

打印输出:4 2 3 1
分析:定时器为宏任务,加入宏任务队列;then方法为异步任务且为微任务,加入微任务队列;console.log打印输出为同步任务,直接打印输出4。由于微任务队列执行先于宏任务队列,因此先考虑2和3的打印输出,此处由入微任务队列先后顺序而定,先输出2,然后输出3,最后考虑输出宏任务队列的1,虽然其延迟时间为0。

  • 同步任务:4
  • 微任务:2 3
  • 宏任务:1

面试题二分析

打印输出:2 5 3 4 1

分析:定时器为宏任务,加入宏任务队列;new Promise为同步任务,执行函数体内resolve方法,首先打印输出2,然后更改Promise实例对象状态为成功;then方法为异步任务,且为微任务,加入微任务队列;console.log打印处处为同步任务,直接打印输出5;因此首先,打印输出同步任务2和5,然后考虑微任务队列,两个then方法执行先后由队列中顺序而定,输出3和4,最后考虑宏任务队列,打印输出1。

  • 同步任务:2 5
  • 微任务:3 4
  • 宏任务:1

面试题三分析

打印输出:1 2 7 5 6 3

分析:定义first函数为同步任务,执行其函数体,在new Promise的实例化方法中,首先执行同步输出1;定义p为一个Promise实例对象也为同步任务,执行函数体,首先打印输出2;定时器为宏任务,加入宏任务队列;执行resolve(5),更改p的状态为成功;执行resolve(6),更改外层Promise实例对象状态为成功;then方法为微任务,加入微任务队列;执行打印输出7。因此目前先执行同步任务,打印输出1、2和7,然后考虑微任务列队里执行先后,由于resolve(5)已更改p的状态为成功,因此首先输出arg:5,然后由于resolve(6)已更改外层Promise实例对象状态为成功,因此输出arg:6,因此目前执行微任务队列,打印输出5和6,最后考虑宏任务队列,打印输出3,但注意此时不会执行resolve(4)再去更改p的状态,因此状态已经由pending变为 resolved。

  • 同步任务:1 2 7
  • 微任务:5 6
  • 宏任务:3

面试题四分析

打印输出:1 7 2 3 8 4 6 5 0

分析:定时器为宏任务,加入宏任务队列;执行new Promise同步任务,首先打印输出1,接着执行resolve更改其实例化对象的状态为成功;then方法为微任务,加入微任务队列;继续执行new Promise同步任务,首先打印输出7,接着执行resolve更改其实例化对象状态为成功;then方法为微任务,加入微任务队列。因此目前首先执行同步任务,输出1和7,然后考虑微任务队列里执行先后顺序,由于已更改第一个Promise实例对象状态为成功,因此执行其链式调用then方法的第一个回调函数,首先打印输出2,接着执行new Promise函数体,首先打印输出3(微任务里),接着执行resolve,更改其实例化对象的状态为成功。由于then方法是异步的,当片段一(代码中已标出)代码没有执行完,片段二是不会执行的,转而会执行片段三,由于执行片段三前已执行resolve,其实例对象状态已变为成功,因此执行片段三的then方法中第一个回调,输出8,接着回到片段一里的第一个then方法,由于已经执行resolve,其实例对象状态已变为成功,因此执行then方法,输出4,此时若片段一中第一个then没有执行完,也不会接着链式执行第二个then。因此接着执行片段二,由于片段一的then方法没有return,因此执行完then的返回值为undefined,当返回值为非Promise对象:undefined时,则得到一个成功的Promise,且其[[PromiseResult]]为undefined,则可以执行then的第一个回调,输出6,同理回到片段一里的第二个then,输出5,最后执行宏队列任务,输出0

重难点:3之后输出8,4之后输出6,是因为then方法是异步的,前一个没有执行完,会接着往下走

  • 同步任务:1 7
  • 微任务:2 3 8 4 6 5
  • 宏任务:0

then方法是异步执行,就是当【.then()】前的方法执行完后再执行【then()】内部的程序
这样就避免了数据没获取到等的问题,语法为【promise.then(onCompleted,onRejected)】。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/36999.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

移动版OpenAI,手机的杀手还是救星?

AI登陆手机&#xff0c;难度因人而异。 原本小编还以为「2023年是属于元宇宙的一年」&#xff0c;实在没想到以ChatGPT为代表的AI技术能在这么短的时间内抢走元宇宙的风头&#xff0c;成为2023年的技术关键词。从OpenAI到搜索引擎、从绘图工具到游戏公司&#xff0c;几乎所有「…

领导讲话云山雾罩像糊弄鬼,这些职场潜规则你知道吗

上一篇&#xff1a;入职银行科技部半年&#xff0c;我已经丧失跳槽的能力了&#xff01; 混迹职场时间久了&#xff0c;就会发现领导职务越高&#xff0c;说话越有水平&#xff0c;也有高度&#xff0c;可是有时让你听的却是云山雾罩&#xff0c;不知道该如何应对。 聪明的人能…

代码的艺术(一)

目录 代码整洁的必要性 为什么要有代码 为什么要写得整洁 整洁的艺术 混乱的代价 整洁的定义 规整端正&#xff0c;符合规范 简洁精炼&#xff0c;便于阅读 什么是整洁的代码 怎样写出整洁的代码 不断改进 不要糊弄 具体做法 有意义的命名 使用函数 注释 勤加…

〖程序员的自我修养 - 优质简历篇①〗- 知己知彼,面试官是如何分析一份简历的

人之所以会觉得迷茫&#xff0c;本质上是欠缺对自己的一个控制力、识别庞杂信息、去伪存真的独立思考能力与认知能力。 说明&#xff1a;该文属于 程序员的自我修养 专栏&#xff0c;购买任意白宝书体系化专栏可加入易编程社区&#xff0c;早鸟价订阅模式除外。福利&#xff1a…

chatgpt赋能python:Python抠图教程:用代码实现高效抠图

Python 抠图教程&#xff1a;用代码实现高效抠图 什么是抠图&#xff1f; 在设计、美术、广告等领域中&#xff0c;经常需要把一张图片中的某个物体或人物单独提取出来&#xff0c;以便于进行后续的处理、叠加、合成等操作。这个过程就叫做抠图。 传统的抠图方式需要用到PS、…

ChatGPT大升级?它去考研能考上物理所吗?

3月15日本应是小编勤勤恳恳搬砖的平凡一天&#xff0c;但小编刚睡醒就发现朋友圈被ChatGPT刷屏了&#xff1a; 新版GPT-4震撼发布&#xff01; 大升级&#xff01;强到爆炸&#xff01; 这些字眼引起了我的兴趣&#xff0c;于是小编迅速入(ke)手(jin)了gpt-4&#xff0c;经过简…

快速构建一个简单的对话+问答AI (上)

文章目录 前言part0 资源准备基本功能语料停用词问答闲聊语料 获取 part01句的表达表达one-hot编码 词嵌入大致原理实现简单版复杂版如何训练 转换后的形状 part02 循环神经网络RNNRNN投影图RNN是三维立体的 LSTM&GRU part03意图识别分词FastText分类FastText网络结构优化点…

Postman请求具有拦截器(登录限制)接口

Postman请求具有拦截器&#xff08;登录限制&#xff09;接口 方法一&#xff1a;注释掉拦截器。 方法二&#xff1a;使用cookie信息 1.登录登陆页获取cookie信息 2.正式调用接口

postman访问提示限制

postman访问http://10.10.171.204:9090/platform/honda/addRtmVehicleTbox提示限制的原因&#xff1a; 被拦截 Websense 类别“Private IP Addresses”已筛选。解决办法&#xff1a; 关掉postman代理设置

PostMan如何模拟get请求

PostMan为调试接口提供了方便的操作&#xff0c;可以配置各种参数&#xff0c;那么使用postman如何模拟get请求&#xff0c;本文对此问题进行简要讲述。 工具/原料 Postman 方法/步骤 1 打开postman&#xff0c;创建一个新的请求。这两有两种方式创建&#xff0c;第一种&…

产研团队任务管理工具:盘点国内外9款知名任务管理系统软件

以下是10款国内外最知名的任务管理系统&#xff1a;1.研发项目任务管理-PingCode&#xff1b;2.通用项目任务管理-Worktile&#xff1b;3.免费开源研发任务工具-Redmine&#xff1b;4.海外著名项目任务管理工具-Asana&#xff1b;5.免费任务管理软件-Trello&#xff1b;6.个人任…

AI绘画的技巧与实践

1.三个不错的AI绘画平台 最近&#xff0c;AI绘画非常流行&#xff0c;只要输入一些关键词&#xff08;prompt脚本&#xff09;&#xff0c;就可以AI帮你绘画出精美的图画&#xff0c;真的很有意思。 在百度上随便搜一下&#xff0c;就能搜出各种乱七八糟的AI绘画平台&#xf…

部署一个人工智能[AI]

基于ChatGPT的大型语言模型。 本教程默认你是Linux平台 安卓端[termux]和Linux[ubuntu]部署教程 下载termux[ubuntu忽略此项]64319 教程开始 1.安装python 安卓端[termux] pkg install python Linux[ubuntu] apt install python 2.安装pip 安卓端[termux] pkg install python-p…

优酷回应非会员收看3000秒广告;亚马逊推出Titan大语言模型;Android 14首个Beta版本释出 | 极客头条...

「极客头条」—— 技术人员的新闻圈&#xff01; CSDN 的读者朋友们早上好哇&#xff0c;「极客头条」来啦&#xff0c;快来看今天都有哪些值得我们技术人关注的重要新闻吧。 整理 | 苏宓 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 一分钟速览新闻点&#xf…

盘古大模型

作者 | gongyouliu 自从去年11月30日openAI发布chatGPT以来&#xff0c;chatGPT引爆了新一轮科技革命。最近很多年都没有哪一项科技进步如chatGPT这般吸引全球的目光。除了媒体的大肆报道&#xff0c;国内外各个科技公司、科研机构、高等院校都在跟进&#xff0c;不到半年时间…

目标检测算法——小目标检测相关数据集(附下载链接)

近期&#xff0c;有小伙伴询问数据集的相关问题&#xff0c;小海带在空闲之余收集整理了一些开源的小目标检测相关的数据集供大家参考。 1.AI-TOD航空图像数据集 数据集下载地址&#xff1a;http://m6z.cn/5MjlYk AI-TOD 在 28,036 张航拍图像中包含 8 个类别的 700,621 个对…

ChatGPTGPT4开源“平替”汇总,持续更新

GPT视频教程 ChatGPT视频教程汇总: https://xueshu.fun/?sgpt ChatGPT/GPT4开源“平替”汇总&#xff0c;持续更新 ChatGPT爆火出圈&#xff0c;国内很多高校、研究机构和企业都发出类似ChatGPT的发布计划。ChatGPT没有开源&#xff0c;复现难度极大&#xff0c;即使到现在G…

微软也搞起了开源小模型!利用OpenAI的ChatGPT和GPT-4 训练,实力碾压当前最强开源模型

来源 | AI前线 ID | ai-front 整理 | 核子可乐&#xff0c;褚杏娟 Chatbot Arena 等排行榜已经反复证明&#xff0c;数十亿美元支撑起来的 ChatGPT 仍然是聊天机器人领域无可争辩的王者。而人们只能调用其 API &#xff0c;无法私有化部署&#xff0c;无法自己训练调整。…

chatgpt赋能python:Python-基于微信API搜索和加入微信群的实现方法

Python-基于微信API搜索和加入微信群的实现方法 随着微信群在社交领域的不断普及&#xff0c;越来越多的用户希望能够快速找到与自己相关的微信群&#xff0c;但是微信上的群搜索机制或者官方推荐机制并不总是满足用户需求。这时候&#xff0c;我们可以借助 Python 的强大功能…

chatgpt赋能python:Python获取微信群二维码

Python获取微信群二维码 微信群是现代社交网络中非常重要的一部分&#xff0c;它是线上社交活动的主要形式之一。微信群中聚集人群的特点和社交效果也吸引了越来越多的人加入。有些微信群还需要二维码来方便加入。 Python是一个非常强大的编程语言&#xff0c;可以通过它来获…