python如何调用c语言代码(c语言,python,开发技术)

时间:2024-05-09 08:37:26 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    python%E5%A6%82%E4%BD%95%E8%B0%83%E7%94%A8c%E8%AF%AD%E8%A8%80%E4%BB%A3%E7%A0%81

linux: python3.5.2 + ubuntu-gnome-16.04-desktop-amd64

windows:cygwin + powershell + python3.6

c与python对比python不擅长"大量运算"任务,python程序优势在于:编写简单,适合"IO密集型作业"(比如打开文件,下载图片,运行脚本)。python作为知名的"胶水语言",快速实现"计算密集型作业"的方法就是"把c的代码拿过来直接用"。

Python中的ctypes模块可能是Python调用C方法中最简单的一种。ctypes模块提供了和C语言兼容的数据类型和函数来加载dll文件,因此在调用时不需对源文件做任何的修改,也正是如此奠定了这种方法的简单性。

1. 准备C语言程序,保存为add.c

2. 编译成so库

Ubuntu下执行:gcc -shared -Wl,-soname,adder -o adder.so -fPIC add.c

3. 准备python代码,保存为python-c.py

4. 测试

执行:python3 python-c.py

结果如下:

4 + 5 = 9

5.5 + 4.1 = 9.600000381469727

5. 说明

在Python文件中,一开始先导入ctypes模块,然后使用cdll.LoadLibrary
函数来加载我们创建的库文件。这样我们就可以通过变量adder来使用C类库中的函数了。当adder.add_int()被调用时,内部将发起一个对C函数add_int的调用。ctypes接口允许我们在调用C函数时使用原生Python中默认的字符串型和整型。

而对于其他类似布尔型和浮点型这样的类型,必须要使用正确的ctype类型才可以。如向adder.add_float()函数传参时, 我们要先将Python中的十进制值转化为c_float类型,然后才能传送给C函数。这种方法虽然简单,清晰,但是却很受限。例如,并不能在C中对对象进行操作。

1. 准备C语言程序,保存为add.c

同上

2. 编译成dll库

cygwin下执行:gcc -shared -Wl,-soname,adder -o adder.dll -fPIC add.c

3. 准备python代码,保存为python-c.py

4. 测试

powershell下执行: .python-c.py

会出现以下错误:

OSError: [WinError 126]

原因:adder.dll本身依赖其它库,需要将这些库一起复制到当前目录。

cygwin下执行:ldd adder.dll

提示依赖以下库

将这些库copy到当前目录,执行:cp xxx.dll .

powershell下再次执行:.python-c.py

本文:python如何调用c语言代码的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:怎么使用SQL实现车流量的计算下一篇:

3 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18