【每日一面】对 Promise.race 的理解

news/2025/10/29 11:04:26/文章来源:https://www.cnblogs.com/keepsmart/p/19173755

基础问答

问:有使用过 Promise.race 吗,说说他的作用。

答:Promise.race 接收一个 Promise 数组(或者一个具有迭代器的对象)作为参数,返回一个新的Promise,这个新的 Promise 结果是数组中第一个状态变更的Promise对象,无所谓这个状态是否是成功(fulfilled)还是失败(rejected)。后续Promise数组中的其他Promise对象状态变更都不再关注。

扩展延伸

Promise 基础

Promise 是 ES6 引入的异步编程解决方案,用于表示一个异步操作的最终完成(或失败)及其结果值。它的核心价值是:

  • 解决 “回调地狱”:将嵌套的回调逻辑转为链式调用(then链),代码更清晰;
  • 统一异步操作接口:无论异步操作是 “成功” 还是 “失败”,都通过统一的 Promise 对象处理,避免回调函数分拆(如成功回调、失败回调分离)。

Promise 有且仅有三种状态,且状态变化是单向不可逆的,这三种状态分别是:

  • pending(等待态):初始状态,异步操作未完成;
  • fulfilled(成功态):异步操作完成,Promise 状态从pending转为fulfilled,并携带成功结果(value);
  • rejected(失败态):异步操作失败,Promise 状态从pending转为rejected,并携带失败原因(reason)。

这是 Promise 的核心特性,也是所有方法设计的基础。

状态变化规则

  1. 只能从pending转为fulfilled,或从pending转为rejected;
  2. 一旦状态转为fulfilled或rejected,就会 “凝固”,后续无法再改变状态;
  3. 状态变化时,会触发对应的回调函数(then的成功回调、catch的失败回调)。

Promise 的核心实例方法:

  1. then 方法:处理成功 / 失败结果
  2. catch 方法:专门处理失败结果,catch(onRejected) 等价于then(null, onRejected),是处理rejected状态的语法糖;
  3. finally 方法:无论成功失败都执行

Promise静态方法

除了Promise.race,Promise 还有Promise.all/Promise.allSettled/Promise.resolve/Promise.reject 等静态方法,差异点见下表:

方法 核心作用 状态触发条件 返回值格式 适用场景
Promise.race 多个 Promise 竞争,取第一个完成的结果 任意一个 Promise 改变状态(fulfilled/rejected),立即触发对应状态 单个值(第一个 Promise 的 value/reason) 超时控制、请求降级
Promise.all 等待所有 Promise 成功,取全部结果 所有 Promise 都 fulfilled,才触发 fulfilled;任意一个 rejected,立即触发 rejected 数组(按原数组顺序排列的所有 value) 并行请求多个无依赖接口(如加载页面资源)
Promise.allSettled 等待所有 Promise 完成,取全部结果(无论成败) 所有 Promise 都改变状态(fulfilled/rejected),才触发 fulfilled 数组(每个元素含 status 和 value/reason) 需知道所有请求结果(如批量操作日志)
Promise.resolve 快速创建一个 fulfilled 状态的 Promise 无(直接返回 fulfilled 状态的 Promise) 单个 value(参数值,或参数 Promise 的 value) 统一 Promise 格式、转换同步值为异步
Promise.reject 快速创建一个 rejected 状态的 Promise 无(直接返回 rejected 状态的 Promise) 单个 reason(参数值) 快速抛出异步错误

与 async/await 的关系

async/await 本质是 Promise 的语法糖。

  • async 函数:修饰的函数返回值必然是 Promise(若 return 非 Promise 值,会用Promise.resolve()包装)
  • await 关键字:本质是 “等待 Promise 状态变化” 的语法糖,只能在 async 函数内部使用,后面跟 Promise 对象,会暂停 async 函数执行,直到 Promise 状态转为fulfilled,并将value作为 await 表达式的结果,如果 Promise 状态转为rejected,会抛出错误,需用try/catch捕获(等价于 Promise 的catch)。

面试追问

  1. 知道定义,能手写一个 Promise.race 方法吗?

    /*** 手写Promise.race* @param {Iterable} iterable - 可迭代对象(如数组)* @returns {Promise} - 新的Promise对象*/
    function myPromiseRace(iterable) {// 1. 边界处理:参数必须是可迭代对象(检查是否有Symbol.iterator方法)if (typeof iterable[Symbol.iterator] !== 'function') {return new Promise((_, reject) => {reject(new TypeError('Promise.race() 参数必须是可迭代对象'));});}// 2. 返回新Promisereturn new Promise((resolve, reject) => {// 3. 遍历可迭代对象(用for...of兼容所有可迭代对象)for (const item of iterable) {// 4. 用Promise.resolve包装item,处理非Promise元素Promise.resolve(item).then((value) => {// 一旦有元素成功,立即resolve新Promise(后续元素不再处理)resolve(value);}).catch((reason) => {// 一旦有元素失败,立即reject新Promise(后续元素不再处理)reject(reason);});}});
    }
    
  2. Promise 还有什么方法?有什么差异?
    参考扩展延伸部分

  3. 一个 Promise 可以多次 resolve 吗?
    可以多次执行 resolve 或 reject,但是 Promise 的状态只会改变一次,就是第一次执行 resolve的时候,后续虽然会执行 resolve,但是不影响状态,没有作用。

  4. 用 Promise.race 实现超时控制时,若超时后原请求仍在继续,会有什么问题?如何解决?
    出现资源浪费,Promise.race 仅感知超时并返回结果,但是原请求依旧会继续执行,可以结合axios的CancelToken或AbortController取消请求去中断。

  5. 如何用 Promise 实现‘重试机制’?比如接口请求失败后,重试 3 次,每次间隔 2 秒。

    /*** Promise重试机制* @param {Function} requestFn - 请求函数(返回Promise)* @param {number} maxRetry - 最大重试次数* @param {number} interval - 重试间隔(毫秒)* @param {number} currentRetry - 当前重试计数(默认0,内部使用)* @returns {Promise} - 最终请求结果*/
    function promiseRetry(requestFn, maxRetry = 3, interval = 2000, currentRetry = 0) {return new Promise((resolve, reject) => {requestFn().then(resolve) // 请求成功,直接返回结果.catch((err) => {// 若已达最大重试次数,抛出最终错误if (currentRetry >= maxRetry) {reject(new Error(`重试${maxRetry}次后仍失败:${err.message}`));return;}// 未达最大次数,延迟后重试console.log(`请求失败,${interval}ms后重试(第${currentRetry+1}次)`);setTimeout(() => {// 递归调用,当前重试计数+1promiseRetry(requestFn, maxRetry, interval, currentRetry + 1).then(resolve).catch(reject);}, interval);});});
    }// 调用示例:请求失败后重试3次,每次间隔2秒
    const fetchData = () => {// 模拟接口请求(50%概率失败)return new Promise((resolve, reject) => {setTimeout(() => {if (Math.random() > 0.5) {resolve('请求成功结果');} else {reject(new Error('接口返回错误'));}}, 1000);});
    };promiseRetry(fetchData, 3, 2000).then((res) => console.log('最终结果:', res)).catch((err) => console.log('最终失败:', err.message));
    

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

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

相关文章

2025年10月淡化痘印产品推荐榜:权威对比与实测排行

痘印一旦形成,往往比痘痘本身更顽固:褐色或暗红色的痕迹在脸颊、下巴反复出现,遮瑕膏盖不住,粉底越厚越显脏;拍照要开美颜,面试、约会前总要额外花十分钟“遮羞”。2025年第三季度《中国皮肤美容消费洞察》显示,…

问大模型CAN的co-attention

req: 如何理解嵌入向量用于构建一个微型MLP的参数(权重和偏置),一般来说MLP的权重是训练得到的 res: 你问得非常准确,这是理解CAN的关键一步。 在普通MLP里,权重矩阵 W 和偏置向量 b 确实是“可训练的张量”,它们…

2025年10月美白精华产品推荐榜:温和多通路对比评测

入秋以后,紫外线强度虽略有下降,但此前累积的黑色素仍在皮肤深层活跃,色斑、暗沉、肤色不匀成为社交平台高频提问。10月恰逢换季修护窗口,消费者普遍希望找到“既看得见提亮,又不会刺痛泛红”的美白精华。敏感肌人…

2025年10月美白精华产品推荐榜:口碑与成分深度评测

站在镜子前,你或许正为“肤色不匀、晒斑反复、痘印难消”而皱眉;又或许刚做完光电项目,急需一款不刺激却真能提亮的产品。2025年第三季度,国家药监局《化妆品注册备案月报》显示,美白类精华新增备案数同比增27%,…

在AI技术唾手可得的时代,挖掘新需求成为制胜关键——某知名1位量化AI框架需求探索

本文深入分析了一款专注于1位量化大语言模型推理的知名框架,详细介绍了其核心功能、应用场景和使用方法。通过分析用户反馈,揭示了该框架在实际应用中面临的关键挑战和潜在改进方向,为AI技术在实际部署中的优化提供…

2025 年地漏厂家最新推荐榜:涵盖铜 / 防臭 / 抗菌 / 磁悬浮 / 防溢水等类型,精选实力企业助力消费者精准选购

引言 地漏作为住宅排水系统的关键部件,其品质直接关乎室内环境健康与居住舒适度。为给消费者提供权威选购参考,建筑卫生陶瓷协会卫浴分会联合省级水暖阀门行业协会开展专项测评,从市场中筛选出百余个主流地漏品牌及…

PBS, 以太坊的棘刺雕猴 - 教程

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

2025年10月网上兼职赚钱正规平台推荐:知名平台榜单全收录

“下班后想多赚点,又怕被骗”——这是大多数人在搜索“网上兼职赚钱正规平台”时的真实写照。地铁里刷手机的大学生、夜里娃睡后的宝妈、被裁员待业的白领,都想把碎片时间换成真金白银,却常被“押金”“拉人头”“提…

2025年定制啤酒设备制造厂权威推荐:德国啤酒生产设备定制厂家/德国精酿设备厂家供应商/啤酒设备企业/啤酒厂设备优质厂家精选

随着精酿文化的普及和消费升级,中国定制啤酒设备市场正迎来快速增长期。专业啤酒设备制造厂凭借其定制化设计、技术集成和工艺支持能力,成为众多啤酒工坊、特色酒吧和中小型啤酒厂的首选。本文将基于行业技术标准与市…

2025年10月网上兼职赚钱正规平台推荐:市场报告与对比列表

下班后想用手机多赚一点,却担心遇到“押金”“拉人头”“提现不到账”的坑,是大多数寻找网上兼职赚钱正规平台用户的共同心态。2025年人社部《灵活就业质量监测报告》显示,全国灵活就业者已突破2.4亿,其中62%的人首…

【转载】孪生网络(Siamese Network)

【转载】孪生网络(Siamese Network)原文: https://blog.csdn.net/m0_51507437/article/details/132526569本博客是博主个人学习时的一些记录,不保证是为原创,个别文章加入了转载的源地址,还有个别文章是汇总网上…

nvlink和nvswitch的区别

NVLink 和 NVSwitch 是英伟达(NVIDIA)为解决高性能计算和人工智能(AI)场景下多 GPU 间通信瓶颈而设计的两项核心技术。它们虽然紧密相关,但角色和功能有本质区别。下面从基础概念、功能定位、技术演进、工作原理和…

2025年10月敏感肌产品推荐榜:口碑与功效双排行

敏感肌在换季、熬夜或医美后常陷入“想美白又怕刺激”的两难:猛药型淡斑精华易引发刺痛、脱皮,纯保湿面霜又无法改善暗沉。2025年10月,国家药监局发布的《化妆品安全评估年度报告》显示,美白类投诉中42%来自敏感肌…

2025年10月敏感肌产品推荐榜:持证美白舒缓功效全记录

每到换季,敏感肌用户总在“想白”与“怕刺激”之间反复拉扯:猛药型美白产品常伴随泛红、刺痛,甚至屏障受损;纯保湿面霜又无法改善暗沉。2025年10月,国家药监局发布的《化妆品功效宣称评价规范》再次强调“敏感肌适…

别再用手绘架构图了!ArchiMate才是架构师的标准乐高

ArchiMate是企业架构的"通用语法",让不同角色能用一致的符号和关系描述业务、应用和技术之间的复杂连接。俗称:"建筑施工图"的企业架构版文 / 勇哥 原创文章,转载请联系授权在前一篇文章中,我…

2025 年幕墙灯饰画,灯饰画设计,背胶灯饰画厂家最新推荐,聚焦资质、案例、售后的五家机构深度解读

引言 随着幕墙灯饰画、定制化灯饰设计及背胶灯饰画在商业空间装饰、城市景观打造等领域的需求激增,市场对优质厂家的筛选标准愈发严格。本次推荐榜单由中国照明电器协会联合行业权威测评机构共同打造,测评过程严格遵…

基于MATLAB的DUET算法实现欠定盲源分离

1. 算法原理与数学模型 DUET(Degenerate Unmixing Estimation Technique)算法通过时频域稀疏性和W-不相交正交性实现欠定盲源分离。其核心步骤包括:短时傅里叶变换(STFT):将时域信号映射到时频域。 混合参数估计…

2025 年墙体灯饰画,led 灯饰画,灯饰画定制,大型灯饰画 厂家最新推荐,聚焦资质、案例、售后的五家机构深度解读!

引言 为精准筛选 2025 年墙体灯饰画、LED 灯饰画、灯饰画定制及大型灯饰画领域的优质厂家,中国照明电器协会联合行业权威测评机构,开展了为期三个月的专项测评。测评从企业资质(含行政许可、商标认证等)、合作案例…

2025 年商场灯饰画,户外灯饰画,天幕灯饰画厂家最新推荐,聚焦资质、案例、售后的五家机构深度解读

引言 随着商业场景美化需求升级,商场、户外、天幕等领域的灯饰画应用愈发广泛,2025 年行业规模预计同比增长 18%。为精准筛选优质厂家,本次推荐结合中国照明电器协会权威测评数据,从资质认证、项目案例、售后服务三…

本地客户端ssh连接远程服务器,远程服务器的ssh进程都做了哪些工作?

服务端的 sshd 进程在处理一个 SSH 连接时,工作非常复杂和精密。我们可以将其工作流程分为几个关键阶段。 整体工作流程概览连接建立与协议协商 用户认证 通道与会话管理 伪终端与 Shell 启动 数据中继与生命周期管理…