一个功能的实现,可以用多种语句来实现,比如说:while语句、for语句、生成器、列表推导、内置函数等实现,然而他们的效率并不一样。写了一个小程序来测试它们执行的效率。
测试内容: 
将一个数字大小为20万的数字,依次取绝对值,放到列表中,测试重复1千次.
测试程序:
 代码如下:
import time,sys  
reps = 1000                #测试重复次数  
nums = 200000              #测试时数字大小  
  
  
def tester(func,*args):    #总体测试函数  
    startTime = time.time()  
    for i in range(reps):  
        func(*args)  
    elapsed = time.time() - startTime #用time模块来测试,结束时间与开始时间差  
    return elapsed  
  
def while_Statement():     #while循环实现  
    res = []  
    x   = 0  
    while nums > x:  
        x += 1  
        res.append(abs(x))  
  
def for_Statement():       #for循环实现  
    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():        #内置函数map实现  
    res = map(abs, range(nums))  
  
  
print sys.version          #打印系统版本  
tests = [while_Statement, for_Statement, generator_Expression, list_Comprehension, map_Function]  
for testfunc in tests:     #将待测函数放置列表中依次遍历  
    print testfunc.__name__.ljust(20),': ',tester(testfunc)  #  
 
测试结果:
 代码如下:
>>>   
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              
新闻热点
疑难解答