Python调用C模块(二): ctypes

前面理了理 用C扩展Python的传统方法(见 ),接下来学习一下 ctypes

ctypes 这个东西到底怎么样的,网络上搜搜资料:似乎有的人对的评价很高,认为很好;有的人则不以为然,认为不怎么方便(特别头文件的东西要实现一遍)。

cdll、windll、oledll

ctypes 会导出 cdll,在windows平台下还会导出 windll 和 oledll。

这三个可以用于导入动态链接库,那么区别是什么呢?

cdll 载入 导出函数 符合cdecl调用规范的库 windll 载入 导出函数 符合 stdcall 调用规范的库,

oledll 也使用 stdcall 调用规范,并假设函数返回Windows的HRESULT错误码(用于在WindowsError这个Python异常)

导入链接库 Windows下

Windows 通常使用".dll"作为动态链接库的扩展名,处理起来比较简单。

直接使用 cdll、windll或oledll的属性操作

>>> from ctypes import *
>>> print windll.kernel32
<WinDLL 'kernel32', handle ... at ...>
>>> print cdll.msvcrt
<CDLL 'msvcrt', handle ... at ...> Linux下

Linux上需要指定包含扩展名的文件名来载入动态库,所以属性存取方式就失效了。

使用 LoadLibrary

或者创建CDLL的实例 >>> cdll.LoadLibrary("libc.so.6")
<CDLL 'libc.so.6', handle ... at ...>
>>> libc==CDLL("libc.so.6")
>>> libc
<CDLL 'libc.so.6', handle ... at ...> 查找链接库 >>> from ctypes.util import find_library
>>> find_library("m")
>>> printf = ctypes.CDLL(find_library("c")).printf 类型 c_char c_wchar c_byte ... c_int ... c_double 等值类型,都是可变的 c_char_p c_wchar_p c_void_p 指针类型,需要小心 >>> s="Hello, world"
>>> c_s=c_char_p(s)

这样赋值,由于python的string是不可变的,这样其实是地址变了。

要用 create_string_buffer 或 create_unicode_buffer

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wywpwf.html