2006年12月06日 星期三 14:05
继续测试ctypes的用法: 下载ctypes,安装好。 先把刚才的静态test.o编译成动态链接库: =>gcc -shared test.o -o test.so 然后=>python >>> from ctypes import * >>> libt = CDLL("test.so") >>> libt>>> a= libt.tadd(1, 3) >>> print a 4 哇哇,好像更加方便了。 总结: 两者都是扩展了python调用外部lib途径。好像pyrex更强调调用静态的lib,而且是把lib编译成python自己原生的module。 为了做到这个,除了有lib的.a文件外,必须要有lib的.h文件。 ctypes则是显示的调用动态的lib,只要有lib的.so,.dll就可以,目前ctypes已经成为2.5的内部module。 而pyrex还有一个比较重要特点就是可以用类c的语法写python的moduele。 比较同意这个观点: > 我觉得 Pyrex 主要是用来为 c 库 提供一个 pythinic 的接口,而非优化python程序。 目前的例子非常简单,复杂情况下的调用有可能出现的问题都还没有碰到。Zoom给的文章里说到的复杂的结构,联合的情况 也还没有尝试。 想到要调用的lib的线程,指针,内存块操作,就有点头痛。 初步还是决定采用ctypes的方式,工作量上要少写一点东西,至少调试的时候也更直接一点。 一切都根据实际情况来做吧,要试错。 > > > > Pyrex 是自动将Python 脚本转化为可编译的C 代码,以便高效执行和被C程序调用; > > > > 我觉得 Pyrex 主要是用来为 c 库 提供一个 pythinic 的接口,而非优化python程序。 > > -- > http://codeplayer.blogspot.com/ -- feihu <feihu.list在gmail.com>
2006年12月06日 星期三 14:41
feihu wrote: > > > 总结: > 两者都是扩展了python调用外部lib途径。好像pyrex更强调调用静态的lib,而且是把lib编译成python自己原生的module。 > 为了做到这个,除了有lib的.a文件外,必须要有lib的.h文件。 > ctypes则是显示的调用动态的lib,只要有lib的.so,.dll就可以,目前ctypes已经成为2.5的内部module。 > 而pyrex还有一个比较重要特点就是可以用类c的语法写python的moduele。 > > 是主要特点, 没有这个pyrex就不是pyrex了. 如果单纯为了包装已经写好的c library, 还是用swig或boost.python比较好. > 比较同意这个观点: > >> 我觉得 Pyrex 主要是用来为 c 库 提供一个 pythinic 的接口,而非优化python程序。 >> > > 这个用swig包装c库, 然后再写一个纯python模块来提供pythonic接口会更省事. pyrex主要不是为了做这个设计的.
Zeuux © 2025
京ICP备05028076号