【细读JS忍者秘籍】深入生成器函数的底层原理

news2024/11/17 21:47:15

深入生成器函数的底层原理

分析执行上下文

生成器函数本质上还是一个_函数_,所以它的执行离不开 执行上下文

function* generator() {console.log("status1");yield "hello";console.log("status2");yield "world";}

let gen = generator();
let one = gen.next(); 

1. 我们试着分析在执行gen = generator() 这句代码前的执行上下文状态:

此时执行上下文栈(后面统称ECS) 中的_栈顶_是 全局执行上下文

该上下文中, 全局对象(window) 上保存了 generator 函数对象。

gen , one 是 let 声明所以在 词法环境中_未进行初始化_

2. 当执行 gen = generator() 时 , 创建 generator 函数的执行上下文:

此时,ECS的_栈顶_是 生成器函数 generator 的执行上下文

从这个时刻开始,就体现出 function *function 的_区别_:

generator 的执行上下文生成好以后,

_不会_和常规的函数一样,开始执行代码。

而是会_创建_一个 指向 generator 执行上下文的 迭代器 并_返回该对象_

注意:

  • 这里并_没有执行_生成器函数内部的代码
  • 生成好执行上下文后,创建了一个指向该上下文环境的对象(被称作_迭代器_)然后返回

和正常的函数一样,生成器函数的上下文被弹出栈顶 (这也是不堵塞挂起的原因)

但由于上下文环境生成的对象_没有失去引用_,因此被保留了下来(和_闭包_一个原理)

执行next 方法

执行 next 方法时,也很_特殊_:

  • 不会_创建 next 方法的上下文,而是将迭代器中保存的_生成器函数的上下文_重新激活_压入栈顶,并从上次挂起的 yeild 位置开始_继续_执行代码。* 从这里可以看出,这就是 生成器函数_不会堵塞_执行的原因,因为_只有执行 next 函数时_,生成器函数的上下文才会被压入栈顶。每次执行到 yeild 关键字就让next返回结果,并_弹出栈顶挂起_,_等待_下次激活。> 你是否还记得 next() 方法的参数?

我们可以在执行 next 方法时传入参数。

该参数很奇怪,会作为_上一次yeild语句的返回值_。

刚开始我会觉得这种设计很奇怪,但是现在看来这是一种很_正常_的逻辑:

我们执行 next 时,将生成器函数从_挂起_状态_恢复_到执行状态。

next方法的_参数_,为这次的_恢复执行_提供了一个_信息_,该信息保存在 上次挂起(这次恢复) 的语句,也就是作为上次yeild语句的返回值

我们通过yeild语句从生成器中_得到_返回值,再使用迭代器的 next 方法把值_传回_生成器,实现了双向通信。

普通函数每次调用都会_创建_一个新的执行上下文,而生成器函数_不同_,自始至终都是使用_一个上下文_,而这个上下文对象由于_被迭代器引用_,所以_不会_被当作垃圾从内存中回收掉。

普通函数的执行上下文只有调用时才新创建,相比之下,生成器函数的上下文会_暂时挂起并在将来恢复_。

总结:

  • 执行生成器函数后,不执行其中的代码,而是_返回一个保存了其上下文对象的迭代器。* 每次调用迭代器的 next 方法,不会_创建 next 方法的上下文,而是_将迭代器中保存的生成器的上下文重新激活压入栈顶。* next 方法的参数作为_上次挂起的语句的返回值。

最后

最近找到一个VUE的文档,它将VUE的各个知识点进行了总结,整理成了《Vue 开发必须知道的36个技巧》。内容比较详实,对各个知识点的讲解也十分到位。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/111465.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Web入门开发【七】- 运行原理

欢迎来到霍大侠的小院,我们来学习Web入门开发的系列课程。 首先我们来了解下这个课程能学到什么? 1、你将可以掌握Web网站的开发全过程。 2、了解基础的HTML,CSS,JavaScript语言。 3、开发自己的第一个网站。 4、认识很多对编…

学到羊之Kafka

1 kafka 是啥 Kafka 是一款开源的消息引擎系统,用来实现解耦的异步式数据传递。即系统 A 发消息给到 消息引擎系统,系统 B 通过消息引擎系统读取 A 发送的消息,在大数据场景下,能达到削峰填谷的效果。 2 Kafka 术语 Kafka 中的分…

性能测试要学习哪些知识?全在这里了

基础:   完整的性能测试流程     需求-计划-方案-环境搭建-用例设计-数据准备-场景设计-脚本开发-脚本执行-结果分析-问题反馈-性能调优-结果报告   性能指标     TPS,QPS,RPS,HPS,RT,VU&#…

【Pandas入门教程】在Pandas中如何创建plots

在Pandas中如何创建plots 来源:Pandas官网:https://pandas.pydata.org/docs/getting_started/intro_tutorials/index.html 文章目录在Pandas中如何创建plots导包数据集准备【小结】导包 import pandas as pd import matplotlib.pyplot as plt数据集准备…

力扣(LeetCode)200. 岛屿数量(C++)

深度优先遍历 求连通块数量。可以遍历所有格子,当格子是岛屿,对岛屿深度优先遍历,找到整个岛,并且将遍历的岛屿标记,以免重复遍历,或递归死循环。标记可以使用状态数组,也可以修改格子的值。本…

SQL注入渗透与攻防(十)之加解密注入和堆叠注入

目录 SQL注入之加解密注入 案列演示 SQL注入之堆叠注入 案列演示 SQL注入之加解密注入 Base64是网络上最常见的用于传输8Bit字节码的编码方式之一,Base64就是一种基于64个可打印字符来表示二进制数据的方法。 案列演示 这里我们拿sql-libs的第二十一关来进行演…

学习TrustZone可以参考的资料

最近看到了一篇学习资料分享的,感觉可以转过来做个记录,除去前辈分享的资料以外,我还觉得ATF的源码里面的DOC目录下的资料也是很不错的,起码可以让你对BL31有个比较不错的认识。当然那个有点太细节了。 最近看PSA安全技术交流微信…

30多岁想转行,零基础学编程,来得及吗?

“30多岁想转行,零基础学编程,来得及吗?能找到好工作吗?”这类问题,总是反复出现。尤其是最近我受《自学是门手艺》鼓舞,也借着参与 xue.cn 的契机想要把 python 学的全面而完整,也总有朋友找我…

从工地打工,到狂揽10个大厂offer、副业赚100万:培训班出来的程序员是怎么做到的?

七年前我 985 毕业却沦落到工地打工,七年后我已经收到了 10 个大厂 offer 。 你好,我是吴师兄,一位曾经的学霸毕业只能去工地,而如今大厂 offer 拿到手软,Github 全球 TOP100 算法仓库创作者,公众号五分钟…

eclipse和sts安装lombok

eclipse和sts安装lombok 说明 sts 是 eclipse集成springboot的开发环境 所以 sts 和 eclipse 安装 lombok 步骤基本一样 参考网址: https://blog.csdn.net/qq_39826207/article/details/119007580?ops_request_misc%257B%2522request%255Fid%2522%253A%252216708973141680…

算法day57|647,516

目录 647. 回文子串 516.最长回文子序列 动态规划总结篇 647. 回文子串 dp数组的定义 dp[i][j]代表的是区间[i,j]的字串是否为回文字符,如果dp[i][j]为true,否则为false 递推公式 如果s[i]和s[j]相等的话 1.ij 为同一个字符,dp[i][j] True 2 i与j相差1…

Kafka大厂高频面试题:在保证高性能、高吞吐的同时保证高可用性

Kafka的消息传输保障机制非常直观。当producer向broker发送消息时,一旦这条消息被commit,由于副本机制(replication)的存在,它就不会丢失。但是如果producer发送数据给broker后,遇到的网络问题而造成通信中…

火山引擎 DataTester 上线“流程画布”功能,支持组合型 A/B 实验分析

更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群 在精细化运营的时代,运营活动同样需要有精细化的策略,例如在年末大促活动中,设计 APP 弹窗提醒、满减、会员领券时,我…

C#语言实例源码系列-实现批量更改文件名称大小写或扩展名

专栏分享点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册 👉关于作者 众所周知,人生是一个漫长的流程,不断克服困难,不断反思前进的过程。在这个过程中…

DeepLearning_Note

这里写目录标题深度学习框架深度学习开发万能公式模型的网络设计和开发:激活函数:几个数据参数:神经网络的输出零碎知识点:深度学习框架 深度学习开发万能公式 ① 问题定义 ② Paddle.vision.datasets(内置数据集&am…

【ROS参数服务器】

参数服务器是以共享方式实现不同节点间数据交互的通信方式。主要用于存储多节点共享的数据,类似于全局变量。ROS中的参数服务器主要包含三个角色,分别是ROS Master(节点管理者)、Talker(参数设置者)、Listener(参数使用者),其中Talker和Liste…

创新京东T7开创“新算法宝典”,图文并茂,全新演绎,太酷了

导言 算法是一门学问,但却总遭到一些程序员的冷落。现在的开发人员,更热衷于编程语言的修炼,以应付面试需求时的需要,所以对算法的学习,稍许忽略了些。实际上,近些年来,各互联网公司对于算法的…

【知识梳理】前端路由的两种模式

一、概述 这是几年前写的的一篇文章,发在了简书上面,现在看来仍然有一些不足,所以再次整理一下发在掘金。 二、什么是单页面应用(SPA)? 首先我们需要了解一下前置的基础知识————SPA(单页面…

S3 #DooTrader 经典组冠军以良好盘感,创下近 900% 收益率摘得桂冠

本届 S3 #DooTrader 慈善杯全球交易大赛现已经进入白热化阶段,第二轮赛事冲刺在即,各位选手摩拳擦掌争取赢得最终的丰厚奖金。目前,领先的选手调整策略和仓位,以保持排位优势。我们看到现阶段经典组 TOP 1 选手已经创造了 1,300% …

WMS类图分析-android12

为什么要分析类图? WMS是一个复杂的模块,就像一个很大的家族,里面有各种角色,认识类图就像是认识WMS模块中的各个角色,不先把人认清楚了,怎么更好的理解他们之间的交互? 我觉得,这…