Python使用ctypes调用C/C++的方法
python使用ctypes调用c/c++
1. ctpes介绍
ctypes is a foreign function library for python. it provides c compatible data types, and allows calling functions in dlls or shared libraries. it can be used to wrap these libraries in pure python.
官方文档地址:
2.使用ctypes调用c语言
python对于标准c的兼容做的相当不错,调用起来相对比较简单,下面给大家上案例
1. 创建一个adder.c文件,代码如下:
#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编写的连个函数,用来计算两个整数相加和两个单精度浮点数相加
2. 编译生成.so文件供python程序调用
在linux环境下使用gcc对adder.c进行编译
命令: gcc adder.c -fpic -shared -o adder.so
3.在python程序中调用.so
创建一个python文件,命令为adder.py,代码如下:
from ctypes import * adder = cdll("./adder.so") res_int = adder.add_int(4,5) print("result: " + str(res_int))
然后在终端里执行命令: python adder.py
执行命令之后就能获得到输出了。
3. 使用ctypes调用c++
与调用c语言不通,在调用c++代码时,需要在源文件中增加一个extern "c"
的代码块
1.创建一个adder_plus.cpp文件,代码如下:
#include <stdio.h> #include <iostream> using namespace std; int add_integer(int a , int b); float add_float(float a, float b); int add_integer(int a , int b){ return a + b; } float add_float(float a, float b){ return a + b; } extern "c"{ int add_integer_plus(int a , int b){ return add_integer(a, b); } float add_float_plus(float a, float b){ return add_float(a ,b); } }
在extern "c"
里的代码是暴露给的python的接口,可以使用cdll进行调用
2. 编译生成.so文件供python程序调用
在linux环境下使用gcc对adder.c进行编译
命令: gcc adder_plus.cpp -fpic -shared -o adder_plus.so
3. 在python文件中调用.so
创建一个python文件,命名为adder_plus.py,代码如下:
from ctypes import * add_plus = cdll('./add_pluse.so') sum = add_plus.add_integer_plus(4,5) print("sum: " + str(sum)) # 使用float类型变量作为函数参数 a = c_float(5.5) b = c_float(4.1) add_float = add_plus.add_float_plus add_float.restype = c_float sum_float = add_plus.add_float_plus(a,b) print(sum_float)
然后在终端里执行命令: python adder_plus.py
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接