自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

立竿見影地把你的 Python 代碼提速7倍

開發(fā) 后端
在我們以前的文章中,曾經(jīng)講過計算斐波那契數(shù)列的幾種方法,其中基于遞歸的方法是速度最慢的,例如計算第40項的值,需要36秒。

 [[322806]]

在我們以前的文章中,曾經(jīng)講過計算斐波那契數(shù)列的幾種方法,其中基于遞歸的方法是速度最慢的,例如計算第40項的值,需要36秒。如下圖所示:

 

要提高運(yùn)算速度,根本辦法當(dāng)然是改進(jìn)算法。不過算法的提高是一個長期積累加上靈機(jī)一動的過程。我們今天要講的,是一個不費(fèi)腦筋,立竿見影的方法——把 Python 代碼編譯成 C 語言代碼。通過 C 語言的運(yùn)行效率來加速計算過程。

這個過程看起來很復(fù)雜,但實際上你并不需要編寫一行 C 語言代碼。你需要做的只是使用一個叫做 Cython 的庫把 Python 代碼編譯為 C 語言代碼即可。

首先我們來安裝 Cython,就像安裝普通的第三方庫一樣:

 

  1. python3 -m pip install cython 

安裝完成以后,我們單獨(dú)寫計算斐波那契數(shù)列的函數(shù):

 

  1. def fib(n): 
  2.     if n in [1, 2]: 
  3.         return 1 
  4.     return fib(n - 1) + fib(n - 2) 

非常簡單的遞歸寫法。然后關(guān)鍵來了,我們要把這個文件保存為fast_fib.pyx。注意后綴是.pyx。如下圖所示:

 

然后我們創(chuàng)建一個setup.py文件,文件內(nèi)容如下:

 

  1. from setuptools import setup 
  2. from Cython.Build import cythonize 
  3.  
  4. setup(ext_modules=cythonize('fast_fib.pyx')) 

如下圖所示:

 

這個文件的作用,就是調(diào)用 Cython 的cythonize函數(shù)把 Python 代碼轉(zhuǎn)換為 C 代碼。

接下來,開始編譯代碼,執(zhí)行如下命令:

 

  1. python3 setup.py build_ext --inplace 

我的 Python 是 Python3.7,所以運(yùn)行完成以后,會生成一個fast_fib.cpython-37m-darwin.so,如果你的 Python 是3.8,這個文件名可能是fast_fib.cpython-38m-darwin.so。這個文件你可以改名字,例如改成fast_fib.so。

還有一個文件叫做fast_fib.c。不過你不用打開這個文件,因為它有3200多行。并且你甚至可以直接把它刪掉。真正有用的只有這個fast_fib.cpython-38m-darwin.so文件。

你需要做的,僅僅是直接調(diào)用你的函數(shù)。我們另外創(chuàng)建一個文件test_fast_fib.py,內(nèi)容如下:

 

  1. import time 
  2. from fast_fib import fib 
  3.  
  4. start = time.time() 
  5. result = fib(40) 
  6. end = time.time() 
  7. print(f'斐波拉契數(shù)列第40項為:{result},耗時:{end - start}秒'

運(yùn)行效果如下圖所示:

 

計算斐波那契數(shù)列第40項只需要5秒鐘,速度妥妥變成 Python 版本的7倍。

使用 Cython,不僅可以提高程序的運(yùn)行速度,還可以把你的核心代碼轉(zhuǎn)換為.so文件,防止別人反編譯看到你的代碼。

關(guān)于 Cython 的更多介紹,請閱讀它的官方文檔[1]

有同學(xué)可能會問,當(dāng)前文件夾下面既然有fast_fib.pyx文件,為什么當(dāng)我們執(zhí)行from fast_fib import fib的時候,不會從這個文件里面導(dǎo)入 Python 版本的代碼?

這是因為,import只會從后綴為.py/.pyc/.pyo/.so的文件中導(dǎo)入模塊,不會進(jìn)入.pyx文件中尋找。

責(zé)任編輯:華軒 來源: 未聞Code
相關(guān)推薦

2025-03-03 00:10:00

密集型NumPyPandas

2012-03-30 10:03:53

2023-03-24 12:39:55

CIOCEO

2017-04-26 10:08:57

臺式機(jī)噪靜音教程

2012-03-15 14:47:41

百度

2018-05-09 14:26:44

提速降費(fèi)新方案

2020-03-09 15:00:35

搜狗AI

2019-09-19 10:23:18

編程手機(jī)微信

2022-07-04 15:44:26

人工智能數(shù)據(jù)中心

2024-01-16 07:48:55

百萬訂單系統(tǒng)

2011-11-15 11:03:48

2020-11-27 06:58:24

索引

2023-03-08 07:46:53

面試官優(yōu)化結(jié)構(gòu)體

2013-08-28 12:36:48

金萬維

2021-09-02 18:02:24

騰訊QQ移動應(yīng)用

2018-03-28 14:10:10

GoPython代碼

2011-12-13 10:11:49

2010-05-27 22:30:08

桌面虛擬化回報

2018-08-13 20:48:20

混改5G中國聯(lián)通

2022-08-09 09:10:31

TaichiPython
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號