0

0

JavaScript中的生成器(Generator)与异步生成器(Async Generator)有何异同?

幻影之瞳

幻影之瞳

发布时间:2025-10-02 15:30:03

|

264人浏览过

|

来源于php中文网

原创

生成器使用function定义,返回可迭代对象,通过yield暂停,用for...of同步遍历;异步生成器用async function定义,返回异步可迭代对象,支持await和自动等待Promise,需用for await...of遍历,适用于流式异步数据处理。

javascript中的生成器(generator)与异步生成器(async generator)有何异同?

生成器(Generator)和异步生成器(Async Generator)都是 JavaScript 中用于创建可迭代对象的特殊函数,它们在处理数据流和异步操作时非常有用。虽然两者结构相似,但在执行方式和使用场景上有明显区别

基本语法与定义

生成器函数通过 function* 定义,调用后返回一个可迭代的生成器对象,使用 yield 暂停执行。

例如:

function* syncGen() {
  yield 1;
  yield 2;
}

异步生成器函数通过 async function* 定义,返回一个异步可迭代对象,同样使用 yield,但每次 yield 可以暂停并等待异步操作完成。

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

例如:

async function* asyncGen() {
  yield await fetch('/api/data');
  yield Promise.resolve(2);
}

返回值与迭代方式不同

生成器返回的是 Generator 对象,它是同步可迭代的,可以用 for...of 遍历。

异步生成器返回的是 AsyncGenerator 对象,必须用 for await...of 来消费其值,因为每个 yield 的结果可能是 Promise。

PictoGraphic
PictoGraphic

AI驱动的矢量插图库和插图生成平台

下载

比如:

// 同步遍历
for (const val of syncGen()) {
  console.log(val);
}

// 异步遍历
for await (const val of asyncGen()) {
  console.log(val);
}

对异步操作的支持能力

普通生成器中的 yield 不会自动处理 Promise,如果 yield 一个 Promise,它只是原样返回,不会等待其 resolve。

而异步生成器中的 yield 可以配合 await 使用,也能直接 yield Promise,系统会在迭代时自动 await。

这意味着异步生成器更适合处理流式异步数据,如逐条读取文件、分页拉取 API 数据等。

错误处理机制差异

在生成器中,错误可通过 try...catch 在函数内部捕获,或通过 generator.throw() 外部注入错误。

异步生成器的错误处理需结合 try...catchawait,因为异常可能来自异步操作,需要用 for await...of 中的异常捕获来处理 rejected 的 Promise。

基本上就这些。两者都基于迭代协议,核心区别在于是否支持异步 yield 和如何被消费。选择哪种取决于你的数据是同步还是异步产生。不复杂但容易忽略。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

531

2023.09.20

console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

415

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

505

2024.05.29

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

483

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

306

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

406

2023.10.12

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

141

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

24

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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