10 迭代器与生成器
迭代與遞歸
迭代器協議:對象必須提供一個next方法 執行該方法要么返回迭代中下一項
要么引起一個stoplteration異常 以終止迭代
可迭代對象: 實現了迭代器協議的對象
協議是一種約定:可迭代對象實現了迭代器協議 Python的內部工具
(如for循環 sum max min函數等等)使用迭代器協議訪問對象
for循環式中 調用了不可迭代對象內部的_iter_方法,把它們變成了可迭代
考慮序列型和非序列型 不可用列表下標 只可迭代器協議
啥是生成器:可以理解為一種數據類型 它自動實現了迭代器協議
故生成器就是可迭代對象
生成器在Python中表現:
1.生成器函數 常規函數定義 但是 使用yield語句而不是return返回結果
yield語句一次返回一個結果
?
2.生成器表達式 類似于列表推導 但是生成器返回按需產生結果的一個對象
而不是構建一個結果列表
生成器的優點:
對延遲操作提供了支持 不是立即產生結果 可在需要時產生
小結:
1,是可迭代對象
2、實現了延遲計算節省內存!
三元表達式
name='alex' res='SB' if name=='alex' else ' 帥 哥' print(res)?
列表解析
?
1.把列表解析的【】換成()得到的就是生成器表達式
2、列表解析與生成器都是一直能夠便利的編程方式,只不過生成器
表達式更省內存
3、Python不但使用迭代器協議 讓for循環更加通用,大部分函數
也是使用迭代器協議訪問對象的
?
#缺點1.占空間大 2.效率低
?
生成器特性:
語法上類似函數:不同于 一次返回一個值
自動實現迭代器協議:
狀態掛起:使用yield返回一個值 然后掛起函數狀態 下次從離開的地方重新開始
優點:延遲計算 一次返回一個結果
提高代碼可讀性
注意事項:生成器只能遍歷一次
生產者消費者模型:
#反例: import time def producer():ret=[]for i in range(100):time.sleep(0.1)ret.append('包子%s'%i)return retdef consumer(res):for index,baozi in enumerate(res):time.sleep(0.1)print('第%s個人,吃了%s'%(index,baozi))res=producer() consumer(res)#yield相當于return控制函數返回值 #x=yield 另一個特性 接受send傳過來的值 賦值給xdef test():print('開始啦')first=yield print('第一次',first)yield 2print('第二次') t=test() res=t._next_() print(res) t._next_() res=t.send('函數停留在first位置 我是給first賦值的') print(res)#正例; def consumer(name):print('我是[%s],我準備開始吃包子了'%name)while True:baozi=yieldprint('%s 開心的吃掉了%s'%[name,baozi]) def producer():c1=consumer('aaa')c2=consumer('bbb_sb')c1.__next__()c2.__next__()for i in range(10):time.sleep(1)c1.send('韭菜餡包子%s',%i)c2.send('韭菜餡包子%s',%i) producer()?
posted on 2019-02-21 22:23 TTNTONZES 閱讀(...) 評論(...) 編輯 收藏轉載于:https://www.cnblogs.com/louzhiyuan/p/10415732.html
總結
以上是生活随笔為你收集整理的10 迭代器与生成器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 凭什么,Netty能成为最流行的NIO框
- 下一篇: 推荐 33 个 IDEA 最牛配置,好用