Python3 生成器的執行流程詳解
生成器,英文名稱generator,形式有兩種:
1.自定義函數,def的函數區塊里加上yield,遇到yield則停止。
2.列表生成器:將列表生成式的[ ],改成( ),即可。
生成器的執行有點難以理解,下面進行解釋說明:
首先,上栗子:
1 def consumer():
2 r='here'
3 while True:
4 n=yield r
5 if not n:
6 return
7 print('[Consumer]Consuming %s...'%n)
8 r='200 OK' +str(n)
9
10 def produce(c):
11 c.send(None)
12 n=0
13 while n<5:
14 n=n+1
15 print('[Producer]Producing %s...' %n)
16 r=c.send(n)
17 print('[Producer]Consumer return: %s' %r)
18 c.close()
19
20 c=consumer()
21 produce(c)
運行結果如下:
[Producer]Producing 1...
[Consumer]Consuming 1...
[Producer]Consumer return: 200 OK1
[Producer]Producing 2...
[Consumer]Consuming 2...
[Producer]Consumer return: 200 OK2
[Producer]Producing 3...
[Consumer]Consuming 3...
[Producer]Consumer return: 200 OK3
[Producer]Producing 4...
[Consumer]Consuming 4...
[Producer]Consumer return: 200 OK4
[Producer]Producing 5...
[Consumer]Consuming 5...
[Producer]Consumer return: 200 OK5
Process finished with exit code 0
運行原理如下:
- 首先是執行第20行,第21行。從第21行傳入參數到第10行,繼續執行第11行,遇到c.send(None),.send是生成器的啟動方法,表示啟動的生成器。
- 程序跳轉,開始執行第1行,一直到第四行,到yield前面為止,第四行不執行,也就是不賦值給n。
- 程序繼續執行第12行,0賦值給n。
- 第13行,進入while循環。第14行,n+1復制給n。第15行,打印
print ('[Producer]Producing %s...' %n)
。 - 執行第16行,遇到c.send(n),啟動生成器,跳轉到程序第4行,將n賦值給n。繼續執行第5行,到8行,由于while循環,繼續執行第4行,遇到yield,停止執行,返回r值,是
'200 OK' +str(n)
。 - 執行第16行,將r賦值給r。繼續執行第17行,由于while循環,從第13行執行一直到第16行,再次遇到c.send(n),啟動生成器,跳轉程序至第4行,將n賦值給n。
- 重復執行第4步和第5步。一直到n值等于5,跳出while循環,執行第15行。遇到c.close(),關閉生成器。函數執行結束。
- 程序執行結束。
參考: