这是我第一次使用Ctypes。我有一个C dll,它对内容添加1进行简单的缓冲区操作。

extern "C"
{
    __declspec(dllexport) int AddBuffer(unsigned char* data, unsigned char len)
    {
        int i = 0;
        int sum = 0;
        for (i = 0; i < len; i++)
        {
            sum = sum + data[i];
            data[i] = data[i] + 1;
        }

        return sum;
    }
}


在我的python代码中

data = [1,2,3,4,5,8,4,6,9]
myfunc = test_dll.AddBuffer
myfunc.argtypes = (ctypes.POINTER(ctypes.c_uint8),ctypes.c_uint8)
data_array = ctypes.c_uint8 * len(data)
result = myfunc(data_array(*data),ctypes.c_uint8(len(data)))
print result
for i in range (0,len(data)):
     print  data[i]


我得到的结果是42,但数据内容保持不变。我已经看过,但仍然找不到原因。

最佳答案

这段代码:


data_array = ctypes.c_uint8 * len(data)
result = myfunc(data_array(*data),ctypes.c_uint8(len(data)))



在名为data的ctypes数组类型的实例中创建data_array的匿名副本。

当您将data_array实例匿名创建到要修改的函数时,即新副本。

相反,您需要:

data = [1,2,3,4,5,8,4,6,9]
myfunc = test_dll.AddBuffer
myfunc.argtypes = (ctypes.POINTER(ctypes.c_uint8),ctypes.c_uint8)
data_array = ctypes.c_uint8 * len(data)
arg = data_array(*data)
result = myfunc(arg,ctypes.sizeof(arg))
print result
for i in range (0,len(arg)):
     print  arg[i]


它将打印出传递给函数的相同数组,并确保传递的数组是命名的,而不是匿名的。

关于python - 用Python包装了C库,但返回的数组未更改,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/36481374/

10-10 21:11
查看更多