Python while、for、生成器、列表推導(dǎo)等語(yǔ)句的執(zhí)行效率測(cè)試
一個(gè)功能的實(shí)現(xiàn),可以用多種語(yǔ)句來(lái)實(shí)現(xiàn),比如說(shuō):while語(yǔ)句、for語(yǔ)句、生成器、列表推導(dǎo)、內(nèi)置函數(shù)等實(shí)現(xiàn),然而他們的效率并不一樣。寫(xiě)了一個(gè)小程序來(lái)測(cè)試它們執(zhí)行的效率。
測(cè)試內(nèi)容:
將一個(gè)數(shù)字大小為20萬(wàn)的數(shù)字,依次取絕對(duì)值,放到列表中,測(cè)試重復(fù)1千次.
測(cè)試程序:
import time,sys
reps = 1000 #測(cè)試重復(fù)次數(shù)
nums = 200000 #測(cè)試時(shí)數(shù)字大小
def tester(func,*args): #總體測(cè)試函數(shù)
startTime = time.time()
for i in range(reps):
func(*args)
elapsed = time.time() - startTime #用time模塊來(lái)測(cè)試,結(jié)束時(shí)間與開(kāi)始時(shí)間差
return elapsed
def while_Statement(): #while循環(huán)實(shí)現(xiàn)
res = []
x = 0
while nums > x:
x += 1
res.append(abs(x))
def for_Statement(): #for循環(huán)實(shí)現(xiàn)
res = []
for x in range(nums):
res.append(abs(x))
def generator_Expression():#生成器實(shí)現(xiàn)
res = list(abs(x) for x in range(nums))
def list_Comprehension(): #列表解析實(shí)現(xiàn)
res = [abs(x) for x in range(nums)]
def map_Function(): #內(nèi)置函數(shù)map實(shí)現(xiàn)
res = map(abs, range(nums))
print sys.version #打印系統(tǒng)版本
tests = [while_Statement, for_Statement, generator_Expression, list_Comprehension, map_Function]
for testfunc in tests: #將待測(cè)函數(shù)放置列表中依次遍歷
print testfunc.__name__.ljust(20),': ',tester(testfunc) #
測(cè)試結(jié)果:
>>>
2.7.4 (default, Apr 6 2013, 19:55:15) [MSC v.1500 64 bit (AMD64)]
while_Statement : 84.5769999027
for_Statement : 75.2709999084
generator_Expression : 62.3519999981
list_Comprehension : 60.4090001583
map_Function : 47.5629999638
改寫(xiě)程序:
import sys
nums = 100
def while_Statement():
res = []
x = 0
while nums > x:
x += 1
res.append(abs(x))
def for_Statement():
res = []
for x in range(nums):
res.append(abs(x))
def generator_Expression():
res = list(abs(x) for x in range(nums))
def list_Comprehension():
res = [abs(x) for x in range(nums)]
def map_Function():
res = map(abs, range(nums))
if __name__=='__main__':
import timeit #用timeit模塊來(lái)測(cè)試
print sys.version
funcs = [while_Statement, for_Statement, generator_Expression, list_Comprehension, map_Function]
for func in funcs:
print func.__name__.ljust(20),': ',timeit.timeit("func()", setup="from __main__ import func")
測(cè)試結(jié)果:
>>>
2.7.4 (default, Apr 6 2013, 19:55:15) [MSC v.1500 64 bit (AMD64)]
while_Statement : 37.1800067428
for_Statement : 30.3999109329
generator_Expression : 27.2597866441
list_Comprehension : 17.386223449
map_Function : 12.7386868963
測(cè)試分析:
用time模塊,和timeit模塊兩種測(cè)試方式測(cè)試了很多組數(shù)字,得出的結(jié)果是執(zhí)行內(nèi)置函數(shù)最快,其次就是列表推導(dǎo),再其次生成器和for循環(huán),while循環(huán)最慢。一般最快的使用內(nèi)置函數(shù)的方法要比使用最慢的while快兩倍以上。簡(jiǎn)單分析下原因:內(nèi)置函數(shù)比如說(shuō)map,filter,reduce(在Python3.0中移除)基本上都是用C語(yǔ)言來(lái)實(shí)現(xiàn)的,所以速度是最快的,列表推導(dǎo)內(nèi)的迭代在解釋器內(nèi)是以C語(yǔ)言的速度運(yùn)行的(一般是for循環(huán)的兩倍,對(duì)大型文件操作而言,用列表推導(dǎo)效果尤其明顯),相比較for循環(huán)代碼是在PVM步進(jìn)運(yùn)行要快的多。但for循環(huán)里面含range(),相對(duì)速度也會(huì)快些,while語(yǔ)句是純粹用Python代碼寫(xiě)成,所以速度最慢。所以函數(shù)式編程最好使用內(nèi)置函數(shù),然后才考慮使用列表推導(dǎo)或for循環(huán)。最好不用while循環(huán).
相關(guān)文章
在Python中操作字典之setdefault()方法的使用
這篇文章主要介紹了在Python中操作字典之setdefault()方法的使用,是Python入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-05-05Python中處理字符串之endswith()方法的使用簡(jiǎn)介
這篇文章主要介紹了Python中處理字符串之endswith()方法的使用,是Python入門(mén)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-05-05Python中類(lèi)的mro與繼承關(guān)系詳解(二)
這篇文章主要介紹了Python中類(lèi)的mro與繼承關(guān)系詳解,上一篇我們已經(jīng)通過(guò)mro相關(guān)資料介紹了mro繼承關(guān)系的基礎(chǔ)內(nèi)容,這片緊接著上一篇文章展開(kāi)詳細(xì)內(nèi)容,需要的朋友可以參考一下2022-07-07Python 使用 consul 做服務(wù)發(fā)現(xiàn)示例詳解
這篇文章主要介紹了Python 使用 consul 做服務(wù)發(fā)現(xiàn)示例詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03手把手教你用Python中的Linting提高代碼質(zhì)量
Python是一種不斷發(fā)展的語(yǔ)言,隨著它的演化和擴(kuò)展,可用工具和開(kāi)發(fā)策略的數(shù)量也在增加,近來(lái)流行的一個(gè)過(guò)程是linting—檢查代碼的潛在問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于用Python中Linting提高代碼質(zhì)量的相關(guān)資料,需要的朋友可以參考下2023-01-01Python裝飾器使用實(shí)例:驗(yàn)證參數(shù)合法性
這篇文章主要介紹了Python裝飾器使用實(shí)例:驗(yàn)證參數(shù)合法性,本文直接給出代碼實(shí)例,代碼中包含詳細(xì)注釋,需要的朋友可以參考下2015-06-06徹底解決No?module?named?‘torch_geometric‘報(bào)錯(cuò)的辦法
這篇文章主要給大家介紹了關(guān)于如何徹底解決No?module?named?‘torch_geometric‘報(bào)錯(cuò)的辦法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-03-03python 中的divmod數(shù)字處理函數(shù)淺析
這篇文章主要介紹了python divmod數(shù)字處理函數(shù)的相關(guān)資料,感興趣的朋友一起看看吧2017-10-10詳解在Python的Django框架中創(chuàng)建模板庫(kù)的方法
這篇文章主要介紹了在Python的Django框架中創(chuàng)建模板庫(kù)的方法,模版庫(kù)通常用來(lái)管理單獨(dú)的Django中的應(yīng)用,需要的朋友可以參考下2015-07-07