python列表索引 python返回迭代器和返回列表有什么區(qū)別?
python返回迭代器和返回列表有什么區(qū)別?在Python中,生成器可以做迭代器所能做的一切,因?yàn)樗鼈兪怯蒳ter()和next()方法自動(dòng)創(chuàng)建的,所以生成器特別簡(jiǎn)潔,而且生成器也很高效,使用生成器表
python返回迭代器和返回列表有什么區(qū)別?
在Python中,生成器可以做迭代器所能做的一切,因?yàn)樗鼈兪怯蒳ter()和next()方法自動(dòng)創(chuàng)建的,所以生成器特別簡(jiǎn)潔,而且生成器也很高效,使用生成器表達(dá)式而不是列表解析,同時(shí)節(jié)省內(nèi)存。除了創(chuàng)建和維護(hù)自動(dòng)生成程序狀態(tài)外,當(dāng)生成器結(jié)束時(shí),它還會(huì)自動(dòng)運(yùn)行出stoperror異常。
列表、元組、字典和字符串都是迭代對(duì)象。
數(shù)字和布爾值不是迭代的。
讓我們來(lái)談?wù)勥@兩者之間的具體區(qū)別:
迭代器對(duì)象需要支持迭代器協(xié)議的對(duì)象。在Python中,為了支持迭代器協(xié)議,需要實(shí)現(xiàn)objectiter和next()方法。其中,iter()方法返回迭代器對(duì)象本身;next()方法返回容器的下一個(gè)元素,在末尾拋出stopiteration異常。
這里有一個(gè)簡(jiǎn)單的迭代器列表:
在閱讀了上面的代碼之后,我想很多人都想知道一個(gè)列表怎么會(huì)有迭代器。由于訪談問題的空間有限,如果您想知道一個(gè)可迭代對(duì)象如何獲得迭代器?
Generator是一個(gè)函數(shù),它為實(shí)現(xiàn)迭代器協(xié)議提供了方便的方法。生成器和普通函數(shù)的區(qū)別在于,它包含一個(gè)yield表達(dá)式,不需要定義iter()和next()。
生成器是一種惰性序列。如果我們需要?jiǎng)?chuàng)建一個(gè)0-1000000000的序列,那么創(chuàng)建這么大的序列將占用更多的內(nèi)存。發(fā)電機(jī)就是為了解決這個(gè)問題。
讓我們舉一個(gè)簡(jiǎn)單的例子來(lái)說明生成器的用法:
如果您有不同的意見,您可以指出并添加到我這里。歡迎留言。