值得一看
广告
彩虹云商城
广告

热门广告位

JavaScript Generator函数原理剖析

Generator函数通过function*定义,使用yield暂停执行并返回遍历器对象;每次调用next()恢复执行,实现可中断的异步流程控制。

javascript generator函数原理剖析

Generator 函数是 JavaScript 中一种特殊的函数类型,它允许你在函数执行过程中暂停和恢复。这种能力使得 Generator 在处理异步流程、迭代器构建以及状态管理等方面非常有用。要理解其原理,需要从语法特性、内部机制与底层实现三个层面来看。

1. 语法特征与基本用法

Generator 函数通过 function* 定义,并使用 yield 关键字来暂停执行:


function* gen() {
  console.log(“A”);
  yield 1;
  console.log(“B”);
  yield 2;
  return “done”;
}

const g = gen();
g.next(); // 输出 A,返回 { value: 1, done: false }
g.next(); // 输出 B,返回 { value: 2, done: false }
g.next(); // 返回 { value: “done”, done: true }

调用 Generator 函数并不会立即执行函数体,而是返回一个 遍历器对象(Iterator)。只有当调用该对象的 next() 方法时,函数才会开始或继续执行,直到遇到下一个 yield 或 return。

2. 执行上下文的暂停与恢复机制

普通函数一旦开始执行,就会一直运行到结束(或抛出异常),而 Generator 的核心在于它可以保存当前执行状态并在之后恢复。

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

这背后依赖于 V8 引擎对执行栈(call stack)和上下文(execution context)的管理方式:

  • 每次遇到 yield,函数会将当前的执行位置、局部变量等状态保留下来
  • 控制权交还给调用者,函数进入“暂停”状态
  • 下一次调用 next() 时,引擎恢复之前保存的上下文,从 yield 后继续执行

这种行为类似于协程(coroutine),即用户态的轻量级线程,可以在多个断点之间切换执行流。

3. 状态机的本质实现

从编译角度看,Generator 函数在底层被转换为一个基于状态机的状态对象。

Babel 或 TypeScript 编译器在没有原生支持的情况下,会将 Generator 转换为一个包含 switch-case 的状态机结构。例如:


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

// 可被转化为类似:
function gen() {
  let state = 0;
  return {
    next() {
      switch (state) {
        case 0:
          state = 1;
          return { value: 1, done: false };
        case 1:
          state = 2;
          return { value: 2, done: false };
        default:
          return { value: undefined, done: true };
      }
    }
  };
}

每个 yield 对应一个状态分支,通过 state 变量追踪当前执行进度。这种方式让函数具备了“可中断”的能力,而无需依赖操作系统的线程调度。

怪兽AI数字人

怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人44

查看详情
怪兽AI数字人

4. yield 与 next 的双向通信

Generator 不只是单向产出值,还可以接收外部输入:


function* gen() {
  const a = yield “hello”;
  console.log(a); // 接收 next 传入的值
}

const g = gen();
g.next(); // { value: “hello”, done: false }
g.next(“world”); // 输出 “world”,{ value: undefined, done: true }

第一次 next() 启动函数并停在第一个 yield;第二次 next(“world”) 不仅恢复执行,还将参数赋值给 yield 表达式的返回结果。这说明 yield 是一个表达式,可以有返回值。

这种双向通信机制是实现复杂控制逻辑的基础,比如用于构建异步流程控制器(如早期的 co 库)。

5. 与 Promise 结合实现异步流程控制

虽然现在普遍使用 async/await,但在 Promise 刚流行时,Generator 常被用来模拟同步写法:


function fetchUser() {
  return fetch(‘/api/user’).then(res => res.json());
}

function* main() {
  try {
    const user = yield fetchUser();
    console.log(user);
  } catch (err) {
    console.error(err);
  }
}

配合一个 runner 函数(如 co),可以自动执行 Generator 并处理 Promise 的 resolve/reject,从而实现“以同步形式书写异步逻辑”。

async 函数本质上就是 Generator + Promise + 自动执行器的语法糖。

基本上就这些。Generator 的本质是一个可暂停、可恢复、支持双向通信的函数,其实现依赖于状态机模型和执行上下文的保存与恢复。尽管现代开发中更多使用 async/await,但理解 Generator 有助于深入掌握 JavaScript 的异步机制和迭代协议设计思想。

相关标签:

javascript java js json typescript 操作系统 栈 ai switch JavaScript typescript json switch try catch Error const 局部变量 栈 线程 console undefined function 对象 default promise 异步

大家都在看:

如何利用JavaScript进行网络请求的拦截和修改?
JavaScript AOP编程实践
JavaScript边缘计算应用
JavaScript中员工数据排名表生成指南:Besson排名法处理并列情况
JavaScript函数式响应式编程
温馨提示: 本文最后更新于2025-10-19 22:40:00,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞12赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容