什么是生成器?
在python中,?要產生一個列表,可以這樣寫:
a=[]??
for i in range(10):
a.append(i*2)
但是,這樣挺麻煩的,產生一個列表,需要三行語句。所以,有人就想到能不能一行代碼來表示呢?其實,也是可以的,如下:
[ i*2 for i in range(10)]
當然,我們也可以寫成[func(i) for i in range(10)]
1、這樣,通過一個式子就能產生一個列表,我們把這樣的式子叫做生成式。
生成式通過算式可以產生符合要求的列表,這個列表是預先產生存在于內存中的,如果列表元素過多,例如100萬,或1000萬個,就占用特別多的內存,所以,具有一定的缺點。而生成器,占用的內存卻是很少的。只要將上方的列表生成式外的方框改成圓括號就算是生成器了。
2、a=(i*2 for i in range(10))
這樣產生的元組就是生成器。
生成器要滿足三個特瞇:
(1)生成器只有在調用時才會產生相應的數據。
(2)只記住當前的位置。
(3)只有一個方法,即__next__()
3、斐波那契數列。
def fib(max):
n,a,b=0,0,1
while n<max:
#print(b)
yield b
a,b=b,a+b #這里相當于t=(b,a+b),a=t[0],b=t[1],和我們平常想的可能有一定的差距。
n=n+1
return('done')
注意:(敲黑板)只要將上方的print(b)改為yield b,此函數就變為了生成器。
變成生成器后有什么好處呢?
訪問生成器fib(x)時,可以用__next__()方式隨意進出,進出自由,而且讀取里面的元素時不須等待時間。不象一次性生成的列表或元組。
yield b?就是返回當前生成器指針所指的值。
?
轉載于:https://www.cnblogs.com/lyzfp/p/11440813.html
總結