溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python 生成器 generator

發(fā)布時(shí)間:2020-06-07 11:19:41 來源:網(wǎng)絡(luò) 閱讀:630 作者:moakia 欄目:編程語言

前提條件: 如果函數(shù)含有yield就是生成器,執(zhí)行過程中遇到y(tǒng)ield就跳出。

舉例:
def gen():
for i in range(10):
x = yield i
print(x)
g=ge()
print(g.send(None)))
print(g.send(2))
Python 生成器 generator
       先說表達(dá)式x = yield i
       如果這個(gè)表達(dá)式只是x = i, 相信每個(gè)人都能理解。即把i的值賦值給了x,而現(xiàn)在等號(hào)右邊是一個(gè)yield i,所以先要執(zhí)行yield i,然后才是賦值。
       因?yàn)樯善饔龅統(tǒng)ield就跳出,所以yield把i值返回到了調(diào)用者那里。
       這個(gè)表達(dá)式的下一步操作:賦值。卻因?yàn)榈忍?hào)右邊的yield被暫停了,換句話說x = yield i才執(zhí)行了一半,當(dāng)調(diào)用者通過send(var)回到生成器函數(shù)時(shí)是回到之前那個(gè)賦值表達(dá)式被暫停的那里,所以接下來執(zhí)行x = yield i的另一半,那就是這個(gè)賦值操作啦,這個(gè)值正是調(diào)用者通過send(var)發(fā)送進(jìn)生成器的值。

再舉例:
def consumer():
r = ''
while True:
n = yield r
if not n:
return
print('[CONSUMER] Consuming %s...' % n)
r = '200 OK'

def produce(c):
c.send(None)
n = 0
while n < 5:
n = n + 1
print('[PRODUCER] Producing %s...' % n)
r = c.send(n)
print('[PRODUCER] Consumer return: %s' % r)
c.close()

c = consumer()
produce(c)
執(zhí)行結(jié)果:
[PRODUCER] Producing 1...
[CONSUMER] Consuming 1...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 2...
[CONSUMER] Consuming 2...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 3...
[CONSUMER] Consuming 3...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 4...
[CONSUMER] Consuming 4...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 5...
[CONSUMER] Consuming 5...
[PRODUCER] Consumer return: 200 OK

官方說明:
注意到consumer函數(shù)是一個(gè)generator,把一個(gè)consumer傳入produce后:
首先調(diào)用c.send(None)啟動(dòng)生成器;然后,一旦生產(chǎn)了東西,通過c.send(n)切換到consumer執(zhí)行;consumer通過yield拿到消息,處理,又通過yield把結(jié)果傳回;produce拿到consumer處理的結(jié)果,繼續(xù)生產(chǎn)下一條消息;produce決定不生產(chǎn)了,通過c.close()關(guān)閉consumer,整個(gè)過程結(jié)束。

我的理解:
       請(qǐng)注意produce()函數(shù)的最開始的地方是c.send(None),正如上面所說這個(gè)操作是初始化generator,并做第一個(gè)yield(遇到consumer函數(shù)就返回),它是有值的,他的值r為'',如果你執(zhí)行命令行的話,你會(huì)發(fā)現(xiàn)結(jié)果先空了一行,就是他的功勞。 然后到n=0+1=1,此時(shí)執(zhí)行c.send(1) ,它開始的位置是在給consumer函數(shù)中的n賦值,即[CONSUMER] Consuming 1 ,繼續(xù)執(zhí)行命令,此時(shí)r被賦值為‘200 ok’ ,因?yàn)閣hile True 會(huì)一直循環(huán),所以繼續(xù)重來,但是生成器遇到y(tǒng)ield 會(huì)自動(dòng)跳出,此時(shí)跳出結(jié)果變成為r=‘200 ok’。
補(bǔ)充知識(shí):
while True :
       只有遇到continue 和break才能跳出循環(huán)。在生成器里面遇到y(tǒng)ield也能。
if not x:相當(dāng)于if x is not Noneif not x is None`
在python中 None, False, 空字符串"", 0, 空列表[], 空字典{}, 空元組()都相當(dāng)于False

參考地址如下:
python
廖雪峰

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI