之前一直只知道yield 是生成器, 但是一直不知道底层原理是怎么实现的,现在做下记录
迭代器
Python中迭代器是需要把数据全部加载到内存中的,如若处理大量数据, 则需要特别大的存储空间。
生成器
生成器是可以迭代的,但是你 只可以读取它一次 ,因为它并不把所有的值放在内存中,它是实时地生成数据。 每次执行到yield的时候函数就会交出运行权, 也就是说程序状态保存下来,下次再迭代的时候会把堆栈和数据信息恢复出来。
yield
第一次迭代中你的函数会执行,从开始到达 yield 关键字,然后返回 yield 后的值作为第一次迭代的返回值. 然后,每次执行这个函数都会继续执行你在函数内部定义的那个循环的下一次,再返回那个值,直到没有可以返回的。
底层实现
栈帧保存了给出代码的的信息和上下文,其中包含最后执行的指令,全局和局部命名空间,异常状态等信息。f_valueblock保存了数据,b_blockstack保存了异常和循环控制方法。
装饰器
简单的说是一个函数包装器, 可以用于权限检验, 一般功能模块的添加等。
原理是 在函数入门之前进入另一个包装函数,这个包装函数可以对这个函数进行修改,或者添加。