首页 > web前端 > js教程 > 正文

JavaScript协程与异步迭代器实现

夢幻星辰
发布: 2025-10-27 19:09:02
原创
871人浏览过
JavaScript虽无传统协程,但可通过生成器和异步迭代器实现类似功能:1. 生成器函数(function)配合yield可暂停并恢复执行;2. 异步生成器(async function)结合for await...of能处理异步数据流;3. 利用run函数调度生成器可模拟协程,管理复杂异步流程。

javascript协程与异步迭代器实现

JavaScript中没有传统意义上的“协程”,但通过生成器(Generator)和异步迭代器,可以实现类似协程的行为。这些特性让函数能够暂停执行、保留状态,并在之后恢复,非常适合处理异步流程和数据流控制。

生成器:实现可暂停的函数

生成器函数使用 function* 定义,调用后返回一个迭代器对象。它可以通过 yield 暂停执行,外部通过 next() 控制恢复。

这种机制允许我们手动控制执行流程,模拟协程的“挂起”与“恢复”行为。

立即学习Java免费学习笔记(深入)”;

function* simpleCoroutine() {
  console.log('Step 1');
  yield 'Paused after step 1';
  console.log('Step 2');
  yield 'Paused after step 2';
  return 'Done';
}
<p>const it = simpleCoroutine();
it.next(); // 输出 Step 1,返回 { value: 'Paused after step 1', done: false }
it.next(); // 输出 Step 2,返回 { value: 'Paused after step 2', done: false }
it.next(); // 返回 { value: 'Done', done: true }</p>
登录后复制

异步迭代器与 for await...of

异步迭代器是返回 { value, done } 的 Promise 对象的迭代器。配合 for await...of 可以简化异步数据流的消费,比如读取分页数据或事件流。

定义异步迭代器最简单的方式是使用异步生成器函数:async function*,它结合了 async/awaityield

ViiTor实时翻译
ViiTor实时翻译

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。

ViiTor实时翻译 116
查看详情 ViiTor实时翻译

立即学习Java免费学习笔记(深入)”;

async function* asyncNumbers() {
  let i = 0;
  while (i < 3) {
    await new Promise(resolve => setTimeout(resolve, 1000));
    yield ++i;
  }
}
<p>// 使用 for await...of 消费异步迭代器
(async () => {
for await (const num of asyncNumbers()) {
console.log(num); // 每秒输出 1, 2, 3
}
})();</p>
登录后复制

模拟协程调度

利用生成器的暂停与恢复能力,可以实现一个简单的协程调度器。这种模式在早期 Promise 普及前常用于管理异步流程(如 co 库)。

立即学习Java免费学习笔记(深入)”;

function run(generatorFn) {
  const iterator = generatorFn();
<p>function handle(result) {
if (result.done) return result.value;
return Promise.resolve(result.value).then(
res => handle(iterator.next(res)),
err => iterator.throw(err)
);
}</p><p>try {
return handle(iterator.next());
} catch (error) {
return Promise.reject(error);
}
}</p><p>// 使用 run 执行“协程”
run(async function*() {
const a = yield fetch('/api/data1').then(r => r.json());
const b = yield fetch('/api/data2').then(r => r.json());
console.log(a, b);
});</p>
登录后复制

基本上就这些。虽然现代 JavaScript 更多使用 async/await,但生成器和异步迭代器依然在处理复杂异步流、惰性求值和自定义控制流时非常有用。理解它们有助于深入掌握 JS 的执行模型。

以上就是JavaScript协程与异步迭代器实现的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号