4

我有一个简单的工作程序,它将intnum_piezas在示例中)从Python函数提交到C++函数。

foo.cpp

#include <iostream>

class Foo{
    public:
        void bar(int number){
            printf("Number is: %d\n", number);
        }
};

extern "C" {
    Foo* Foo_new(){ return new Foo(); }
    void Foo_bar(Foo* foo, int number){ foo->bar(number); }
}

fooWrapper.py

from ctypes import cdll
lib = cdll.LoadLibrary('./libfoo.so')

class Foo(object):
    def __init__(self):
        self.obj = lib.Foo_new()

    def bar(self, num_piezas):
        lib.Foo_bar(self.obj, num_piezas)

num_piezas = 5    
f = Foo()
f.bar(num_piezas)

问题是现在我想发送一个int数组和一个char数组以及该数字。所以我尝试了:

foo.cpp

#include <iostream>
#include <string.h>

class Foo{
    public:
        void bar(int number, int piezas[3], char prioridades[3][20]){
            printf("Number is: %d\n", number);
            for(int i=0;i<3;i++) {
                printf("%d", piezas[i]);
            }
            for(int q=0;q<3;q++) {
                printf("%s ", prioridades[q]);
            }
        }
};

extern "C" {
    Foo* Foo_new(){ return new Foo(); }
    void Foo_bar(Foo* foo, int number, int piezas[3], char prioridades[3][20]){ foo->bar(number, piezas, prioridades); }
}

fooWrapper.py

from ctypes import cdll
lib = cdll.LoadLibrary('./libfoo.so')

class Foo(object):
    def __init__(self):
        self.obj = lib.Foo_new()

    def bar(self, num_piezas, piezas, prioridades):
        lib.Foo_bar(self.obj, num_piezas, piezas, prioridades)

piezas = [1, 2, 3]
prioridades = ['normal', 'baja', 'primera pieza']
num_piezas = 5    
f = Foo()
f.bar(num_piezas, piezas, prioridades)

C++文件可以正确编译,但是当我尝试执行 Python 函数 ( python fooWrapper.py) 时,会显示此错误消息:

Traceback (most recent call last):
  File "fooWrapper.py", line 15, in <module>
    f.bar(num_piezas, piezas, prioridades)
  File "fooWrapper.py", line 9, in bar
    lib.Foo_bar(self.obj, num_piezas, piezas, prioridades)
ctypes.ArgumentError: argument 3: <type 'exceptions.TypeError'>: Don't know how to convert parameter 3

我做错了什么?我是否需要做其他事情才能将它intstring数组作为参数传递?提前致谢。

4

2 回答 2

6

你可以摆脱这个修改:

from ctypes import c_int, c_char

...

# create a 3-int array
piezas = (c_int*3)()
piezas[0] = 1
piezas[1] = 2
piezas[2] = 3

# create a 3-(20-char array) array
prio = ((c_char*20)*3)()
prio[0].value = "normal"
prio[1].value = "baja"
prio[2].value = "primera pieza"

但由于您在 C++ 端处理 char 数组,我建议您更改函数定义为 : void Bar( int num, char* piezas, int len_piezas, char** prio , int len_prio_elem, int prio);。它要长得多,但是如果要避免缓冲区溢出,则必须控制输入数组的长度。

于 2013-08-07T11:34:44.720 回答
1

您需要使用 CFUNCTYPE 定义一个函数原型(阅读文档),然后使用新类型包装您的函数,之后您将获得类型化函数。每次您想使用带有 args 或返回类型不同于 int 的 c 函数时,您都必须这样做。

http://docs.python.org/2/library/ctypes.html#function-prototypes

http://docs.python.org/2/library/ctypes.html#callback-functions

Python 列表和 c 数组是不同的。您可以在 python 中定义 c-array 类型,请阅读此处:

http://docs.python.org/2/library/ctypes.html#arrays

于 2013-08-07T11:16:01.900 回答