首先了解一个斐波那契函数的实现,了解下生成器的工作流程 # coding=utf-8 # Author: RyAn Bi def fib(max): n,a,b=0,0,1 while n < max: #print(b) yield b #定义一个生成器,也是个断点,每次运行都会再此调用 a,b = b,b+a n = n +1 return 'done' f=fib(2) while True: try: #定义一个异常处理 x= next(f) #运行下一步 print('f:',x) e…
生成器就是一个返回迭代器(iterator)的函数. 包含了 yield 的函数,就是一个生成器. 生成器每使用yield语句产生一个值,函数就会被冻结(暂停执行),被唤醒后(即再次调用)接着上次执行,继续产生新的值. 一个函数中可以包含多个yield,原理不变. 在一些情况下使用生成器可以节省存储空间. 示例一: def gen(): for i in range(5): yield i*2 for i in gen(): print(i) -------------------- 0 2 4…