cython_进阶

https://mp.csdn.net/postedit/88421373

使用cython只快了9S,是因为我们编译的是纯python代码

查看编译性能:cython -a test.pyx  会生成一个html

黄色:更多的python虚拟机调用

白色:非python虚拟机调用

看到这里还不够,继续用line_profiler  逐行对代码分析,为快速检验,减少10倍数据量

黄色标记为最耗时与调用次数最多的行,但for循环无法改为C,高兴的是我们可以放心的使用range循环,cython会将其优化为c类型的for语句形如: for (i = 0; i < 100; i++)

我们仅用cdef 对变量增加类型

import time
def prime_num(int max_num):
    cdef unsigned num,i
    for num in range(2, max_num):
        if num < 2:
            pass
        elif num == 2:
            pass
        else:
            for i in range(2, num):
                if num % i == 0:
                    break
            else:
                print(num)
if __name__=='__main__':
    start=time.time()
    prime_num(100000)
    print(time.time()-start)

这里明显,黄色的地方减少,这代表这更多的非python虚拟机调用,这样会加快我们程序的运行

import test
import time
start=time.time()
test.prime_num(100000)
print(time.time()-start)  

'''
0.9663772583007812
'''

综合:

python:22.940618753433228

cython(纯python风格)+python:13.06978225708008

pypy+cython:1.6705870628356934

python+js:1.4169998168945312

cython(内嵌C风格)+python:0.9663772583007812

猜你喜欢

转载自blog.csdn.net/rookie_is_me/article/details/88971732