淺談Python中列表生成式和生成器的區(qū)別
列表生成式語法:
[x*x for x in range(0,10)] //列表生成式,這里是中括號 //結(jié)果 [0, 1, 4, 9, 16, 25, 36, 49, 64, 81] (x*x for x in range(0,10)) //生成器, 這里是小括號 //結(jié)果 <generator object <genexpr> at 0x7f0b072e6140>
二者的區(qū)別很明顯:
一個直接返回了表達式的結(jié)果列表, 而另一個是一個對象,該對象包含了對表達式結(jié)果的計算引用, 通過循環(huán)可以直接輸出
g = (x*x for x in range(0,10)) for n in g: print n
結(jié)果
0 1 4 9 16 25 36 49 64 81
當表達式的結(jié)果數(shù)量較少的時候, 使用列表生成式還好, 一旦數(shù)量級過大, 那么列表生成式就會占用很大的內(nèi)存,
而生成器并不是立即把結(jié)果寫入內(nèi)存, 而是保存的一種計算方式, 通過不斷的獲取, 可以獲取到相應(yīng)的位置的值,所以占用的內(nèi)存僅僅是對計算對象的保存
相關(guān)文章
python GoogleIt庫實現(xiàn)在Google搜索引擎上快速搜索
這篇文章主要為大家介紹了python GoogleIt庫實現(xiàn)在Google搜索引擎上快速搜索功能探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01

