自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Python中的yield到底是個(gè)什么鬼?

開發(fā) 后端
相信你已經(jīng)不止一次在函數(shù)中看到關(guān)鍵詞yield,它起著什么作用?返回什么?和return又有著什么區(qū)別呢?這篇文章將會(huì)揭開yield的神秘面紗,并給出最淺顯易懂的例子。

相信你已經(jīng)不止一次在函數(shù)中看到關(guān)鍵詞yield,它起著什么作用?返回什么?和return又有著什么區(qū)別呢?這篇文章將會(huì)揭開yield的神秘面紗,并給出最淺顯易懂的例子。

yield關(guān)鍵字做了什么?

如果不太好理解yield,可以先把yield當(dāng)作return的同胞兄弟來看,他們都在函數(shù)中使用,并履行著返回某種結(jié)果的職責(zé)。

這兩者的區(qū)別是:

有return的函數(shù)直接返回所有結(jié)果,程序終止不再運(yùn)行,并銷毀局部變量;

而有yield的函數(shù)則返回一個(gè)可迭代的 generator(生成器)對(duì)象,你可以使用for循環(huán)或者調(diào)用next()方法遍歷生成器對(duì)象來提取結(jié)果。

什么是生成器呢?在 Python 中,使用了yield的函數(shù)被稱為生成器。有點(diǎn)套娃的感覺,但事實(shí)就是這樣,調(diào)用一個(gè)yield函數(shù),就會(huì)返回一個(gè)生成器對(duì)象。

在調(diào)用生成器函數(shù)的過程中,每次遇到 yield 時(shí)函數(shù)會(huì)暫停并保存當(dāng)前所有的運(yùn)行信息(保留局部變量),返回yield的值, 并在下一次執(zhí)行next()方法時(shí)從當(dāng)前位置繼續(xù)運(yùn)行,直到生成器被全部遍歷完。

先看一個(gè)簡單的例子:

上面函數(shù)返回一個(gè)生成器,現(xiàn)在對(duì)該生成器進(jìn)行遍歷:

或者調(diào)用next()方法:

可以看到,simple_generator函數(shù)返回一個(gè)生成器,調(diào)用next()方法后,函數(shù)開始運(yùn)行,遇到第一個(gè)yield關(guān)鍵字,返回生成的值(1),程序暫停;

第二次調(diào)用next()方法,代碼從上次暫停的位置開始執(zhí)行,并遇到了第二個(gè)yield關(guān)鍵字,再返回生成的值(2),程序暫停;

第三次調(diào)用也是如此,返回生成的值(3),生成器耗盡,程序終止;

到這里你可能就明白yield和return的關(guān)系和區(qū)別了,帶yield的函數(shù)是一個(gè)生成器,這個(gè)生成器有一個(gè)方法就是next,next就相當(dāng)于“下一步”生成哪個(gè)數(shù),這一次的next開始的地方是接著上一次的next停止的地方執(zhí)行的。

所以調(diào)用next的時(shí)候,生成器并不會(huì)從函數(shù)的開始執(zhí)行,只是接著上一步停止的地方開始,然后遇到y(tǒng)ield后,return出要生成的數(shù),此步就結(jié)束。

有個(gè)經(jīng)典的例子就是使用yield生成斐波那契數(shù)列:

  1. def fab(max):  
  2.     n, a, b = 0, 0, 1  
  3.     while n < max:  
  4.         yield b      # 使用 yield 
  5.   
  6.         a, bb = b, a + b  
  7.         nn = n + 1 
  8.   
  9. for n in fab(5):  
  10.     print n 

生成器有哪些作用?

如果想具體化數(shù)據(jù)的形式,通常會(huì)將數(shù)據(jù)存儲(chǔ)在一個(gè)列表中。但這樣做,列表的內(nèi)容將占用有形內(nèi)存。列表越大,占用的內(nèi)存資源就越多。

但是,如果數(shù)據(jù)集有某種邏輯,就不必存儲(chǔ)在一個(gè)列表中,只需編寫一個(gè)生成器,它將在需要時(shí)生成這些值,基本不占用內(nèi)存。

 

責(zé)任編輯:趙寧寧 來源: Python大數(shù)據(jù)分析
相關(guān)推薦

2022-02-16 20:04:08

容器KubernetesShim

2021-03-06 09:18:51

JS閉包函數(shù)

2020-09-27 06:53:57

MavenCDNwrapper

2019-10-30 10:13:15

區(qū)塊鏈技術(shù)支付寶

2024-09-11 13:58:18

2024-07-12 15:08:23

Python@wraps函數(shù)

2022-02-22 13:20:57

RSA算法加密

2012-02-13 15:50:59

2021-01-29 12:24:22

電腦電子計(jì)算機(jī)

2021-03-22 07:45:05

Sentinel微服務(wù)開源的項(xiàng)目

2022-04-10 19:26:07

TypeScript類型語法

2024-01-16 23:30:46

?fractionsPython分?jǐn)?shù)

2022-01-10 11:16:40

漏洞 Log4j2Jndi

2021-01-08 09:48:18

Pythonname變量

2021-02-18 07:43:25

TCP協(xié)議網(wǎng)絡(luò)

2016-10-21 09:58:19

WindowsKMSOEM系統(tǒng)

2018-09-06 11:20:24

CDNDDoS網(wǎng)站

2024-07-03 12:04:42

C++this?

2015-05-21 15:45:13

2024-08-26 14:23:56

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)