Promise,async,await 面试题

目录

  • 5,面试题
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

推荐先看Promise 相关知识点

5,面试题

1

结果 1,5,2,3,4

const promise = new Promise((resolve, reject) => {console.log(1);setTimeout(() => {console.log(2);resolve();console.log(3);});
});promise.then(() => {console.log(4);
});console.log(5);

因为 then() 中的回调函数虽然是微任务,但也得等到 promise 变为 fulfilled 状态才会执行。

2

结果 1,3,2

async function fun() {console.log(1); // 同步const n = await 2;console.log(n);
}fun();
console.log(3);

因为 fun() 函数中的同步语句会直接执行,异步的才会延迟执行。

// 相当于
function fun() {console.log(1);Promise.resolve(2).then((n) => {console.log(n);})
}

3

结果 1,4,2,3

async function fun() {console.log(1); // 同步const n = await 2;console.log(n);
}(async () => {await fun();console.log(3);
})();console.log(4);

同理,立即执行函数执行后,await fun() 中的同步代码先执行,异步代码进入微队列等待执行。所以先输出 1 后输出 4。

4

结果 Promise {<pending>},Promise {<pending>},4,1,3,1

async function fun1() {return 1;
}async function fun2() {const n = await fun1();console.log(n); // 1return 2; // 没用被用到
}async function fun3() {const n = fun2(); // 注意没有 awaitconsole.log(n);return 3;
}fun3().then((n) => {console.log(n); // n 是 fun3 的返回值 3
});fun3();console.log(4);

1,先看同步代码的执行。

  • 第1个 fun3() 执行,会执行 fun2(),再执行 await fun1(),会将 async fun1 返回的 Promise 对象的后续处理,放到微队列中等待执行(任务1)。
const n = await fun1();
console.log(n);// 相当于
new Promise((resolve) => {resolve(1)
}).then((n) => {console.log(n);
})
  • 因为 fun2async 修饰,而且还有异步代码,所以此时 fun2() 执行的结果是一个 pending 状态的 Promise 对象,所以输出 Promise {<pending>}fun3() 的后续处理:then() 的回调函数进入微队列等待执行(任务2)。
  • 第2个 fun3() 执行,再次输出 Promise {<pending>},并添加微任务3
  • 输出 4

2,接下来看异步代码的执行。

  • 执行微队列中的任务1输出 1,任务2输出 3,任务3输出 1

5

结果 1

Promise.resolve(1).then(2).then(Promise.resolve(3)).then(console.log)

参考 3.2 的知识点。then() 的参数不是函数,说明没有对前一个任务做后续处理,相当于无效代码。

// 等价
Promise.resolve(1).then(console.log)

6

结果:promise1,undefined,end,promise2,promise3,promise4,Promise {<pending>},after1

var a
var b = new Promise((resolve, reject) => {console.log('promise1')setTimeout(() => {resolve()}, 1000)
}).then(() => {console.log('promise2')}).then(() => {console.log('promise3')}).then(() => {console.log('promise4')})a = new Promise(async (resolve, reject) => {console.log(a)await bconsole.log(a)console.log('after1')await aresolve(true)console.log('after2')
})
console.log('end')

注意,ba 都是右边 Promise 执行的结果。右边先执行,再赋值给左边的变量。

1,先看同步代码执行

  • 执行 b 右边的表达式,输出 promise1setTimeout 的回调函数进入宏队列等待执行。此时 b 被赋值为一个 pending 状态的 Promise 对象。
  • 执行 a 右边的表达式,输出 undefined(此时 a 未赋值)。
  • 执行 await b,因为此时 bpending 状态,所以后续代码都不会执行,所以 a 也被赋值为一个 pending 状态的 Promise 对象
  • 输出 end

2,再看异步代码执行

  • 没有微队列,所以执行宏队列中 setTimeout 的回调函数,将 b 变为 fulfilled 状态,接着执行后续 3个 then(),依次输出 promise2promise3promise4
  • 现在 b 变为 fulfilled 状态,所以 await b 执行完成,开始执行后续代码。
  • 注意到 a 现在还是一个 pending 状态的 Promise 对象,所以输出 Promise {<pending>} ,再输出 after1
  • 执行 await a,将永远等待,因为没有更改状态的机会。

7

结果 script start,async1 start,async2,p1,script end,async1 end,p2,settimeout

async function async1() {console.log('async1 start')await async2()console.log('async1 end')
}async function async2() {console.log('async2')
}console.log('script start')setTimeout(() => {console.log('settimeout')
}, 0)async1()new Promise(function (resolve) {console.log('p1')resolve()
}).then(function () {console.log('p2')
})console.log('script end')

1,先看同步代码执行

  • 输出 script startsetTimeout 的回调函数进入宏队列等待执行。
  • 执行 async1(),输出 async1 start
  • 执行 await async2() 中的同步代码,输出 async2await async2() 之后的代码,相当于在 then() 的回调函数中执行,所以进入微队列等待。
await async2()
console.log('async1 end')async function async2() {console.log('async2')
}// 相当于
new Promise((resolve) => {console.log('async2')resolve()
}).then(() => {console.log('async1 end')
})
  • 输出 p1then() 的回调函数进入微队列等待。
  • 输出 script end

2,再看异步代码执行。

  • 先执行微队列中的任务,输出 async1 end,再输出 p2
  • 再执行宏队列中的任务,输出 settimeout

以上。

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

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

相关文章

【LeetCode刷题篇零】一些基础算法知识和前置技能(下)

数组常用技巧 使用数组代替Map 使用另一个数组来统计每个数字出现的次数&#xff0c;数组的下标作为key, 数组的值作为value&#xff0c; 将数字作为数组的下标索引&#xff0c;数组里的值存储该数字出现的次数&#xff0c;原理有点类似桶排序中使用的计数数组。 比如这里如…

小程序赖加载刷新数据页面数据堆叠问题debug

目录 项目所需 原生写赖加载存在的bug 解决问题思路及代码实现 思路&#xff1a; 代码实现&#xff1a; 列表.wxml 列表.js Wenjain_shanchu.js Wenjain_shanchu.json Wenjain_shanchu.wxml shouye.js ⭐️ 好书推荐 【内容简介】 项目所需 某高校大一新生入学&am…

​LeetCode解法汇总2605. 从两个数字数组里生成最小数字

目录链接&#xff1a; 力扣编程题-解法汇总_分享记录-CSDN博客 GitHub同步刷题项目&#xff1a; GitHub - September26/java-algorithms: 算法题汇总&#xff0c;包含牛客&#xff0c;leetCode&#xff0c;lintCode等网站题目的解法和代码&#xff0c;以及完整的mode类&#…

EasyPHP-Devserver-17安装和配置mantisBT

文章目录 1、准备工作2、安装easyphp2.1 http://127.0.0.1 无法访问 3、安装mantisBT和phpMyAdmin3.1 配置浏览器的访问url和端口号&#xff08;配置局域网内可访问&#xff09;3.2 安装mantis 4、Administrator 注册新用户时设置登录密码5、附件上传6、邮件配置 文章参考自&am…

【广州华锐互动】煤矿提升机作业VR互动实训平台

在煤矿行业中&#xff0c;安全性是无可忽视的首要任务。传统的煤矿工人培训方法&#xff0c;如理论课堂讲解、实地操作演示&#xff0c;尽管具有一定的效果&#xff0c;但往往无法真实地模拟出煤矿的复杂环境&#xff0c;工作人员在没有真正接触煤矿的情况下&#xff0c;很难理…

【LLM】Windows本地CPU部署民间版中文羊驼模型(Chinese-LLaMA-Alpaca)踩坑记录

目录 前言 准备工作 Git Python3.9 Cmake 下载模型 合并模型 部署模型 前言 想必有小伙伴也想跟我一样体验下部署大语言模型, 但碍于经济实力, 不过民间上出现了大量的量化模型, 我们平民也能体验体验啦~, 该模型可以在笔记本电脑上部署, 确保你电脑至少有16G运行…

【Face Swapping综述】Quick Overview of Face Swap Deep Fakes

【Face Swapping综述】Quick Overview of Face Swap Deep Fakes 0、前言Abstract1. Introduction2. Face Swapping Process2.1. Preprocessing2.2. Identity Extraction2.3. Attributes Extractor2.4. Generator2.5. Postprocessing2.6. Evaluation Methods3. Challenges4. Con…

【GO语言基础】变量常量

系列文章目录 【Go语言学习】ide安装与配置 【GO语言基础】前言 【GO语言基础】变量常量 【GO语言基础】数据类型 文章目录 系列文章目录常量和枚举变量声明全局变量声明大小写敏感 总结 常量和枚举 使用const关键字声明常量&#xff0c;并为每个常量提供显式的值。Go语言没有…

在Windows上通过SSH公私钥实现无密码登录Linux

在Windows上通过SSH公私钥实现无密码登录Linux 在Windows上生成SSH密钥对&#xff1a; 打开命令提示符或PowerShell窗口。 输入以下命令生成SSH密钥对&#xff1a; ssh-keygen -t rsa -b 4096按照提示输入密钥的保存路径和密码&#xff08;可选&#xff09;。 在指定的路径下…

嵌入式学习笔记(26)5S5PV210串行通信编程实战

5.5.1整个流程分析 整个串口通信相关程序包含2部分&#xff1a;uart_init负责初始化串口&#xff0c;uart_putc负责发送一个字节 5.5.2串口初始化关键步骤 &#xff08;1&#xff09;初始化串口的Tx和Rx引脚所对应的GPIO(查原理图可知Tx和Rx分别对应GPA0_1和GPA0_0) &#…

解决“您在 /var/spool/mail/root 中有新邮件”问题

一、发现问题 二、解决问题 1、删除邮件 cat /dev/null > /var/spool/mail/root 2、禁止系统启动邮件检查 echo "unset MAILCHECK" >> /etc/profile 三、解决结果

Matplotlib | 高阶绘图案例【3】- 五大战区高校排名

文章目录 &#x1f3f3;️‍&#x1f308; 1. 导入模块&#x1f3f3;️‍&#x1f308; 2. 数据处理2.1 高效数据2.2 学校排名 &#x1f3f3;️‍&#x1f308; 3. 绘图3.1 绘制图布&#xff0c;设置极坐标系3.2 绘制学校排名柱状图3.3 绘制五大战区扇形区域3.4 添加战区、学校…

关于安卓13中Android/data目录下的文件夹只能查看无法进行删改的问题

前言 因为升级了安卓13&#xff0c;然后有个app需要恢复数据&#xff0c;打算和以前一样直接删除Android/data下对应目录再添加&#xff0c;结果不行&#xff0c;以下是结合网上以及自己手机情况来做的一种解决方案。 解决 准备&#xff1a; 待恢复app&#xff08;包名com.…

Pytest系列- assert断言详细使用(4)

简介 在断言方面&#xff0c;pytest框架比其他类似的框架&#xff08;比如unittest&#xff09;更加简洁&#xff0c;易用&#xff0c;我想这是选择pytest作为自动化测试框架之一的原因之一。pytest的assert断言关键字支持使用python内置的assert表达式。可以理解为pytest的断…

正则匹配字符串中电话号码的中间几位为指定字符

今天遇到一个需求,要替换字符串中的电话号码的中间几位为星号, 泥马之前是后端做得,现在要我前端弄 , 心里一万个 艹 * 马............. 此处省略9997个字 . 直接上代码------- , 这里的字符做了连续判断,如果两个电话号码是连续的,就不做处理, 希望能帮到抓耳挠腮的你------ …

数据结构题型6-后插结点操作

#include <iostream> //引入头文件 using namespace std;typedef int Elemtype;#define Maxsize 100 #define ERROR 0 #define OK 1typedef struct LNode {Elemtype data;//数据域struct LNode* next;//指针域 }LNode, * LinkList;bool InitList(LinkList& L) …

Spring的组件扫描配置

<context:component-scan base-package"com.lyh.ssm.controller"><context:exclude-filter type"annotation" expression"org.springframework.stereotype.Controller"/></context:component-scan>这段配置是针对Spring的组件…

Container is running beyond memory limits

问题 Hadoop环境中&#xff0c;执行MapReduce程序或者Hive 任务时候&#xff0c;任务执行失败&#xff0c;提示内存不足。 Container is running 337869312B beyond the VIRTUAL’ memory limit.Current usage:295.8 NB of 1 GB physical memoryused;2.4 GB of 2.1 GB virtual…

PMP认证可以用来干什么呢?

PMP(项目管理专业人士&#xff09;认证是一项国际上广为认可的专业认证&#xff0c;具有以下几个重要用途和好处&#xff1a; 1. 提升职业竞争力&#xff1a; PMP认证是项目管理领域具有权威性和声誉的认证之一。持有PMP认证可以证明你具备了相关知识、技能和经验&#xff0c…

Layui + Flask | 表单元素(组件篇)(06)

表单元素是输入框、选择框、复选框、开关、单选框等表单项组件,用于对表单域进行输入。layui 的表单元素对原生的表单元素进行了大幅的用着,有好看的 UI 同时又有非常方便操作的 API。 输入框 https://layui.dev/docs/2.8/form/input.html 输入框组件是对文本框 <input ty…