0

0

什么是javascript的生成器函数_yield关键字如何控制执行流程

紅蓮之龍

紅蓮之龍

发布时间:2026-01-10 21:11:11

|

460人浏览过

|

来源于php中文网

原创

生成器函数用function*声明,调用后返回generator对象且不立即执行;需调用next()启动或恢复,遇yield暂停并返回值,状态保留,终止后next()恒返{value:undefined,done:true}。

什么是javascript的生成器函数_yield关键字如何控制执行流程

生成器函数声明和调用后不立即执行

生成器函数不是普通函数,它用 function* 声明,调用后返回一个 Generator 对象,而不是直接运行函数体。这个对象是“可迭代的”,但内部状态初始为 suspended —— 什么都没执行。

必须显式调用 next() 才会启动或恢复执行,直到遇到第一个 yield 或函数结束。

function* count() {
  console.log('start');
  yield 1;
  console.log('after first yield');
  yield 2;
}
const gen = count(); // ← 此时 'start' 还没打印
gen.next(); // → { value: 1, done: false },同时打印 'start'
gen.next(); // → { value: 2, done: false },同时打印 'after first yield'

yield 是暂停点,不是返回值语句

yield 暂停函数执行,并把右侧表达式的值作为 next() 返回对象的 value。函数上下文(变量、执行位置)被完整保留,下次 next() 从下一行继续。

  • yield 右侧表达式只在本次 next() 调用时求值
  • 如果 yield 后面没有值(如 yield;),valueundefined
  • yield 表达式本身的结果,是下一次 next(value) 传入的 value(可用于双向通信)
function* echo() {
  const a = yield 'first';
  console.log('a =', a); // ← 下次 next(123) 传入的 123 在这里接收
  const b = yield 'second';
  return b * 2;
}
const g = echo();
g.next();      // → { value: 'first', done: false }
g.next(123);   // → { value: 'second', done: false },并打印 'a = 123'
g.next(456);   // → { value: 912, done: true }

生成器终止后再次调用 next() 总是返回 { value: undefined, done: true }

一旦生成器函数 return(显式或隐式)或抛出未捕获错误,状态变为 closed。此后所有 next() 调用都返回固定结果,不会重跑、不会报错、也不会触发 finally 块(如果有的话)。

Uni-CourseHelper
Uni-CourseHelper

私人AI助教,高效学习工具

下载

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

  • 多次 next() 不会重复执行 return 后的代码
  • throw()return() 也可提前终止,效果等同于自然结束
  • 已终止的生成器无法重用,必须重新调用生成器函数创建新实例
function* once() {
  yield 1;
  return 'done';
}
const g = once();
g.next(); // → { value: 1, done: false }
g.next(); // → { value: 'done', done: true }
g.next(); // → { value: undefined, done: true } ← 不变
g.next(); // → { value: undefined, done: true } ← 依然不变

生成器常用于实现惰性序列和异步流程控制

因为能暂停/恢复且保持状态,生成器天然适合封装「按需计算」逻辑,比如无限数列、文件逐块读取;配合 async/await(如 co 库或手动包装),还能模拟协程式异步写法。

  • 避免一次性生成大数据集,节省内存
  • for...of、展开语法 [...gen]Array.from(gen) 配合使用最自然
  • 注意:原生 async function* 是异步迭代器,和同步生成器行为不同,不要混用 yieldawait 在同一个函数里(除非用 async function*

真正容易被忽略的是:生成器函数内部的 try...finally 块,在 returnthrow 终止时会执行,但在外部多次调用 next() 导致的「静默终止」中,finally 只触发一次 —— 就是那个让状态变成 done: true 的那次调用。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6102

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3302

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

1545

2025.12.25

function是什么
function是什么

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

497

2023.08.04

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

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

166

2023.10.07

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

5

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

11

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

33

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

25

2026.03.03

热门下载

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

精品课程

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

共58课时 | 5.7万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

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

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