Python中的ctypes模塊可能是Python調(diào)用C方法中最簡單的一種。ctypes模塊提供了和C語言兼容的數(shù)據(jù)類型和函數(shù)來加載dll文件,因此在調(diào)用時(shí)不需對源文件做任何的修改。也正是如此奠定了這種方法的簡單性。
示例如下
實(shí)現(xiàn)兩數(shù)求和的C代碼,保存為add.c
//sample C file to add 2 numbers - int and floats
#include <stdio.h>
int add_int(int, int);
float add_float(float, float);
int add_int(int num1, int num2){
return num1 + num2;
}
float add_float(float num1, float num2){
return num1 + num2;
}
接下來將C文件編譯為.so
文件(windows下為DLL)。下面操作會(huì)生成adder.so文件
#For Linux
$ gcc -shared -Wl,-soname,adder -o adder.so -fPIC add.c
#For Mac
$ gcc -shared -Wl,-install_name,adder.so -o adder.so -fPIC add.c
現(xiàn)在在你的Python代碼中來調(diào)用它
from ctypes import *
#load the shared object file
adder = CDLL('./adder.so')
#Find sum of integers
res_int = adder.add_int(4,5)
print "Sum of 4 and 5 = " + str(res_int)
#Find sum of floats
a = c_float(5.5)
b = c_float(4.1)
add_float = adder.add_float
add_float.restype = c_float
print "Sum of 5.5 and 4.1 = ", str(add_float(a, b))
輸出如下
Sum of 4 and 5 = 9
Sum of 5.5 and 4.1 = 9.60000038147
在這個(gè)例子中,C文件是自解釋的,它包含兩個(gè)函數(shù),分別實(shí)現(xiàn)了整形求和和浮點(diǎn)型求和。
在Python文件中,一開始先導(dǎo)入ctypes模塊,然后使用CDLL函數(shù)來加載我們創(chuàng)建的庫文件。這樣我們就可以通過變量adder
來使用C類庫中的函數(shù)了。當(dāng)adder.add_int()
被調(diào)用時(shí),內(nèi)部將發(fā)起一個(gè)對C函數(shù)add_int
的調(diào)用。ctypes接口允許我們在調(diào)用C函數(shù)時(shí)使用原生Python中默認(rèn)的字符串型和整型。
而對于其他類似布爾型和浮點(diǎn)型這樣的類型,必須要使用正確的ctype類型才可以。如向adder.add_float()
函數(shù)傳參時(shí), 我們要先將Python中的十進(jìn)制值轉(zhuǎn)化為c_float類型,然后才能傳送給C函數(shù)。這種方法雖然簡單,清晰,但是卻很受限。例如,并不能在C中對對象進(jìn)行操作。