久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

python 如何區分return和yield

瀏覽:5日期:2022-07-10 13:32:11

一、說明

return一直中,每中語言中其沒沒有很大差別,就不多說了。(shell語言return的是退出狀態,可能差別是比較大的,感興趣可參見“Linux Shell函數定義與調用”)

最早看到yield應該是哪們語言用來調整什么線程優先級的,記不清了,不過那里的yield和python中的yield應該功能有區別。

python中最早看到yield應該是使用scrapy框架寫爬蟲的時候,之前也有去看yiled的用法,總記不太住。今天又去看了一下,基本上來就是講些斐波那契數列的煩的要死,自己寫段程序研究了一下,這里記一下。

二、return和yield的異同

共同點:return和yield都用來返回值;在一次性地返回所有值場景中return和yield的作用是一樣的。

不同點:如果要返回的數據是通過for等循環生成的迭代器類型數據(如列表、元組),return只能在循環外部一次性地返回,yeild則可以在循環內部逐個元素返回。下邊我們舉例說明這個不同點。

三、實例說明

3.1 return版本

示例代碼如下:

class TestYield: def gen_iterator(self): result_list = [] for j in range(3): print(f'gen_iterator-{j}') result_list.append(j) # return在循環的外部,待變量完全生成后一次性返回 return result_list def call_gen_iterator(self): # 執行下邊這句后result_list直接是完成的結果[0,1,2] result_list = self.gen_iterator() for i in result_list: print(f'call_gen_iterator-{i}')if __name__ == '__main__': obj = TestYield() obj.call_gen_iterator()

執行結果如下,可以看到一次性執行完下層函數,生成完整的迭代器類型返回值result_list,一次性返回給上層函數:

python 如何區分return和yield

3.2 yield版本

示例代碼如下:

class TestYield: def gen_iterator(self): for j in range(3): print(f'do_something-{j}') # yield在for循環內部 yield j def call_gen_iterator(self): # yield并不是直接返回[0,1,2],執行下邊這句后result_list什么值都沒有 result_list = self.gen_iterator() # i每請求一個數據,才會觸發gen_iterator生成一個數據 for i in result_list: print(f'call_gen_iterator-{i}')if __name__ == '__main__': obj = TestYield() obj.call_gen_iterator()

執行結果如下,可以看到上下層函數是交替進行的,即上層函數請求迭代一個值下層函數才生成一個值并立即返回這個值:

python 如何區分return和yield

3.3 yield的意義

從上邊兩個小節可以看到,雖然return和yield兩者執行的順序有區別,但整個要做的事情是一樣的,所以使用yield并不會比return快,甚至我們可以猜測由于yield總發生上下文切換在速度上還會慢一些,所以速度不是yield的意義。

他們的主要區別是yiled要迭代到哪個元素那個元素才即時地生成,而return要用一個中間變量result_list保存返回值,當result_list的長度很長且每個組成元素內容很大時將會耗費比較大的內存,此時yield相對return才有優勢。

四、yield和return嵌套使用

class TestYield: def gen_iterator(self): for j in range(3): print(f'do_something-{j}') # yield在for循環內部 yield j def gen_iterator_middle(self): print(f'gen_iterator_middle') # 返回的是迭代器的句柄,所以加一層return不影響是可以理解的 return self.gen_iterator() def call_gen_iterator(self): # yield并不是直接返回[0,1,2],執行下邊這句后result_list什么值都沒有 result_list = self.gen_iterator_middle() # i每請求一個數據,才會觸發gen_iterator生成一個數據 for i in result_list: print(f'call_gen_iterator-{i}')if __name__ == '__main__': obj = TestYield() obj.call_gen_iterator()

python 如何區分return和yield

以上就是python 如何區分return和yield的詳細內容,更多關于python return和yield的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 久久三区 | 久久综合九九 | 草草网站 | 日韩欧美视频 | 九九国产| 一区二区三区四区 | 久久免费视频3 | 亚洲1级片 | 欧美日韩国产在线观看 | 国产精品嫩草55av | 中文字幕精品一区二区三区精品 | 日本久久精品 | 国产精品精品视频一区二区三区 | 日本99精品 | 亚洲精品久久久久一区二区三区 | 国产欧美日韩精品一区 | 中文字幕精品一区 | 色爱av| 在线观看成人小视频 | 精品免费久久久久 | 日韩精品一区二区在线观看视频 | 在线一级视频 | 羞羞羞网站 | 综合久久久 | 日韩区 | 欧美久久一区二区三区 | 精品中文一区 | 中文字幕2021 | 91久久精品一区二区别 | 欧美激情在线精品一区二区三区 | 日韩资源在线 | 男女免费在线观看视频 | 亚洲一区二区中文字幕 | 久久久国产精品入口麻豆 | 国产中文字幕一区 | 国产精品成人一区二区 | 欧美午夜精品久久久久免费视 | 国产一级免费视频 | 免费的一级视频 | 毛片激情永久免费 | 国产情侣av自拍 |