gpt4 book ai didi

python中使用ctypes调用so传参设置遇到的问题及解决方法

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 28 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章python中使用ctypes调用so传参设置遇到的问题及解决方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

问题 。

近日在做一组声纹聚类时,使用了另一团队同学开发的声纹距离算法。该算法对外提供的是一组so包,需要使用方自己去使用。在python中调用纯so包一般使用ctypes类库,用起来看起来简单但也有不少细节容易犯错。本次使用过程中,就遇到传参的问题.

目标so库中对外export的函数是大致如下的三个函数

?
1
2
3
void * create_handler();
   int extract_feature(void * hander);
   bool destroy(void * handler);

这三个函数使用起来倒也简单,顺序使用就可以了。但发现写成如下形式的python代码后,执行会直接segment fault.

?
1
2
3
4
5
6
import sys
   import ctypes
   so = ctypes.cdll( "./lib/libbase.so" )
   p = so.create_handler()
   feature = so.extract_feature(p)
   so.destroy(p)

解决 。

这段代码中p是int类型,由void*自动转来,在ctyeps中这种转型本身是没问题的。segment fault发生在extract_feature函数调用中,问题应当出在参数上,回传的handler已经不是原来的pointer了,导致访问指针出错.

查阅ctypes的文档后,发现ctypes可以声明so库中函数的参数,返回类型。试了试,显示声明后问题得到了解决,证明我们的猜想是对的,确实指针发生了变化。修改后代码如下

?
1
2
3
4
5
6
7
8
9
import sys
   import ctypes
   so = ctypes.cdll( "./lib/libbase.so" )
   so.create_handler.restype = ctypes.c_void_p
   so.extract_feature.argtypes = [ctypes.c_void_p]
   so.destroy.argtypes = [ctypes.c_void_p]
   p = so.create_handler()
   feature = so.extract_feature(p)
   so.destroy(p)

结论

ctypes中传递指针类型参数需要显示声明c函数的参数,返回类型.

总结 。

以上所述是小编给大家介绍的python中使用ctypes调用so传参设置遇到的问题及解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

原文链接:https://segmentfault.com/a/1190000019516590 。

最后此篇关于python中使用ctypes调用so传参设置遇到的问题及解决方法的文章就讲到这里了,如果你想了解更多关于python中使用ctypes调用so传参设置遇到的问题及解决方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com