亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python while、for、生成器、列表推導(dǎo)等語(yǔ)句的執(zhí)行效率測(cè)試

 更新時(shí)間:2015年06月03日 11:34:21   投稿:junjie  
這篇文章主要介紹了Python while、for、生成器、列表推導(dǎo)等語(yǔ)句的執(zhí)行效率測(cè)試,本文分別用兩段程序測(cè)算出了各語(yǔ)句的執(zhí)行效率,然后總結(jié)了什么情況下使用什么語(yǔ)句優(yōu)先使用的語(yǔ)句等,需要的朋友可以參考下

一個(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è)試程序:

復(fù)制代碼 代碼如下:

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é)果:

復(fù)制代碼 代碼如下:

>>>  
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ě)程序:
復(fù)制代碼 代碼如下:

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é)果:

復(fù)制代碼 代碼如下:

>>>  
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)文章

最新評(píng)論