实现异步操作sleep

这两个函数 sleepdelay 都是使用 JavaScript 的 Promise 和 setTimeout 来实现异步操作的。不过它们的功能略有不同,下面我为你详细解释:

sleep 函数

sleep 函数接受一个秒数 seconds,并返回一个 Promise,该 Promise 在指定的秒数后解析。它主要用于在异步操作中模拟等待或延迟。

复制代码
const sleep = (seconds) => new Promise(resolve => setTimeout(resolve, seconds));

// 使用示例
async function demo() {
  console.log('开始');
  await sleep(2); // 等待2秒
  console.log('2秒后');
}

demo();

delay 函数

delay 函数接受一个函数 func、一个秒数 seconds 和一些额外的参数 ...args。这个函数返回一个 Promise,该 Promise 在指定的秒数后调用传入的函数 func 并将其结果作为 Promise 的解析值。如果 func 函数抛出异常,那么 delay 返回的 Promise 会被拒绝。

复制代码
function delay (func, seconds, ...args) {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      Promise.resolve(func(...args)).then(resolve, reject); // 注意这里也处理了reject
    }, seconds);
  });
}

// 使用示例
function greet(name) {
  return `Hello, ${name}!`;
}

delay(greet, 2000, 'World').then(result => console.log(result)); // 等待2秒后输出 "Hello, World!"

注意事项

  • delay 函数中,Promise.resolve(func(...args)) 是为了确保即使 func 不是一个返回 Promise 的函数,我们也能以统一的方式处理其返回值或抛出的异常。
  • 如果 func 是一个返回 Promise 的函数,那么 delay 也会等待这个 Promise 解析或拒绝后再继续。
  • delay 的实现中,我们同时处理了 resolvereject 的情况,以确保即使 func 抛出异常,delay 返回的 Promise 也能正确地拒绝。
  • delay 函数提供了更高级的功能,因为它允许你在延迟后执行任意函数并处理其结果或异常。而 sleep 函数则更简单,只是简单地等待一段时间。
相关推荐
飞翔的佩奇1 小时前
【完整源码+数据集+部署教程】表盘指针检测系统源码和数据集:改进yolo11-CA-HSFPN
python·yolo·计算机视觉·数据集·yolo11·表盘指针检测
larance1 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
在努力的前端小白2 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
搏博2 小时前
基于Python3.10.6与jieba库的中文分词模型接口在Windows Server 2022上的实现与部署教程
windows·python·自然语言处理·flask·中文分词
麦兜*3 小时前
Swift + Xcode 开发环境搭建终极指南
开发语言·ios·swiftui·xcode·swift·苹果vision pro·swift5.6.3
lxmyzzs3 小时前
pyqt5无法显示opencv绘制文本和掩码信息
python·qt·opencv
专注API从业者3 小时前
Python + 淘宝 API 开发:自动化采集商品数据的完整流程
大数据·运维·前端·数据挖掘·自动化
萧鼎4 小时前
Python pyzmq 库详解:从入门到高性能分布式通信
开发语言·分布式·python
烛阴4 小时前
TypeScript高手密技:解密类型断言、非空断言与 `const` 断言
前端·javascript·typescript
一叶飘零_sweeeet4 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8