python核心编制之生成器
python核心编制之生成器
该文档仅用作学习笔记,转载请表明出处
什么是生成器
- 通过列表生成式,我们可以直接创建一个列表,但是,收到内存的限制,列表容量肯定是有限的而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面的几个元素,那后面绝大多数元素占用的空间都白白浪费了,所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间。
- 在python中,这种一边循环一边计算的机制,称为生成器。generator。
创建生成器方法1
- 要创建一个生成器,有很多方法,第一种方法很简单,只要把一个列表生成式的[]改成()
- 案例v29:
'''
创建生成器方法1
'''
l = [x * 2 for x in range(5) ]
print(l)
L = (x * 2 for x in range(5) )
print(L)
for i in L:
print(i)
输出的结果为:
创建生成器的第二种方法
案例v30:斐波那契数列。
from time import sleep
def feibonaqieFunc():
a,b = 0,1
while True:
yield (b)
a,b = b,a+b
sleep(1)
a = feibonaqieFunc()
while True:
print(next(a))
sleep(0.1)
输出结果为:
send
- 当执行到yield时,gen函数作用暂时保存,返回i的值;temp接受下次c.send(‘python’),send发送多来的值。c.next()等价c.send(None)
- 案例31:
def gen():
i = 0
while i<5 :
#yield i
temp = yield i
print(temp)
i += 1
a = gen()
#next(a)
#next(a)
#next(a)
print(next(a))
print(next(a))
print(next(a))
print(next(a))
print(next(a))
输出结果为: