这是我第一次使用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/