python ctypes - 传递numpy数组 - 奇数输出

toe*_*ebs 5 python ctypes numpy

我正在使用ctypes,我正在将一个ndarray传递给一个c函数.它给了我奇怪的输出行为.下面是一些代码:

C-功能:

int foo(int * foo,int N){
for(int i=0;i<N;i++){
    cout << "i " << i  << " "<< foo[i]  << endl;
    }
return 0;
}
Run Code Online (Sandbox Code Playgroud)

蟒蛇:

from ctypes import *
import numpy as np
bar = cdll.LoadLibrary(".../libtest.so")
N = c_int(10)
check = np.ones(10, dtype=int)
print check
bar.foo(c_int(check.ctypes.data),N)
Run Code Online (Sandbox Code Playgroud)

输出:

[1 1 1 1 1 1 1 1 1 1]
i:0 out:1
i:1 out:0
i:2 out:1
i:3 out:0
i:4 out:1
i:5 out:0
i:6 out:1
i:7 out:0
i:8 out:1
i:9 out:0
Run Code Online (Sandbox Code Playgroud)

一切都对吗?:)

我正在编译

g++ -g -c -fPIC -O0  pythagoras.cpp 
g++ -shared -Wl,-soname=libtest.so -o libtest.so  pythagoras.o 
Run Code Online (Sandbox Code Playgroud)

任何想法?我现在正在寻找失败至少1小时,我不知道解决方案是什么(可能是一些愚蠢的事情)

提前致谢!

Ery*_*Sun 4

设置dtype为 Pythonint将使用 C long。如果您使用的是 64 位平台(Windows 除外),则这是 64 位数据类型,这解释了交错的 0。您可以通过设置dtype=np.int32vs来检查这一点dtype=np.int64

其次,是一个代表 C指针的check.ctypes.dataPython 。传递它是不正确的。至少,使用和定义:intvoid *c_intc_void_pargtypes

from ctypes import *
import numpy as np

bar = CDLL('.../libtest.so')
bar.foo.argtypes = [c_void_p, c_int]
Run Code Online (Sandbox Code Playgroud)

check.ctypes定义了_as_parameter_ctypes 钩子,它返回一个实例c_void_p

N = 10
check = np.ones(N, dtype=np.int32)
print check
bar.foo(check.ctypes, N)
Run Code Online (Sandbox Code Playgroud)

您可以使用 更具体check.ctypes.data_as,或者使用 定义类型np.ctypeslib.ndpointer

顺便说一句,foo是一个 C++ 函数,而不是 C。您一定使用过extern "C". 否则导出的名称将被破坏。