Python ctypes,将 c_void_p 作为输出参数传递给 c 函数

col*_*nec 5 c++ python ctypes

我正在编写一个包装一些 C++ 代码的 Python 模块。我曾经使用这个函数将指针从 C++ 传递到 Python(该指针将由不同的函数释放

DLLEXPORT void* run(double input1, double input2)
Run Code Online (Sandbox Code Playgroud)

我添加了错误返回代码,所以我的新函数看起来像

DLLEXPORT int run(double input1, double input2, void* output)
Run Code Online (Sandbox Code Playgroud)

但现在我似乎无法获取指针的值,在Python中我使用ctypes设置函数如下

from ctypes import *
mydll = cdll.mydll

mydll.run.argtypes = [c_double, # input 1
                      c_double, # input 2
                      c_void_p] # output pointer
mydll.run.restype  = c_int   
Run Code Online (Sandbox Code Playgroud)

然后我通过在 Python 中创建一个新的 void 指针并将其传递给 dll 函数来使用该函数

p = c_void_p()

retval = mydll.run(1.2, 3.4, p)

print p
Run Code Online (Sandbox Code Playgroud)

运行此代码后,我留下p等于c_void_p(None).

将此指针传递给其他函数会导致地址 0x0 处出现非法访问异常,因此我认为它没有被更新。

我预计p执行后会填充一些地址。我缺少 ctypes 的东西吗?我可以通过分配创建一个双精度数组(c_double * 10)()并将其传递给要写入的 c 函数,为什么我不能出于相同目的传递 void 指针?

Mar*_*nen 5

正如 eryksun 的评论指出的那样,作为void*输出参数,它应该是void**

# DLLEXPORT int run(double input1, double input2, void** output)

from ctypes import *
mydll = cdll.mydll

mydll.run.argtypes = [c_double, # input 1
                      c_double, # input 2
                      POINTER(c_void_p)] # output pointer
mydll.run.restype  = c_int

p = c_void_p()
retval = mydll.run(1.2,3.4,byref(p))

print p.contents
Run Code Online (Sandbox Code Playgroud)