6

我正在通过 Python 运行 C++ 代码,并且想腌制一个扩展类型。

所以我有一个 C++ 结构 (py_db_manager),其中包含指向数据库对象和对象管理器对象(均用 C++ 编写)的指针,我用 python 类型对象 (t_db_manager) 包装了它。我的问题是这种python类型需要知道如何腌制两个指针才能将它发送到一些子多核进程。所以我用 copy_reg 模块注册了类型(这相当于在类型上写了一个reduce () 方法。但是,我不太确定要放什么。我应该用 PyObject* 构建一个元组还是只是整数指针?有人可以帮忙吗?

typedef struct
{
  PyObject_HEAD
  PyObject* man_inst_ ;
  PyObject* db_inst_ ;

}py_db_manager;`

这是 Py_TypeObject

PyTypeObject t_db_manager = {
    PyObject_HEAD_INIT(0)               /* tp_head */
    0,                                  /* tp_internal */
    ".py_db_manager",                  /* tp_name */
    sizeof(py_db_manager)};

这是reduce方法中的代码:

PyObject *pickle_manager(PyObject *module, PyObject *args)
{
    py_db_manager *cpp_manager =0;
    PyObject *values = NULL,
        *tuple = NULL;
    char text[512];

    if (!PyArg_ParseTuple(args, "O!", &t_db_manager, &cpp_manager))
        goto error;
    sprintf(text,"man_inst_, db_inst_");
    if ((values = Py_BuildValue("(sii)", text,
                                cpp_manager->man_inst_, cpp_manager->db_inst_)) == NULL)
        goto error;
    tuple = Py_BuildValue("(OO)", manager_constructor, values);

error:
    Py_XDECREF(values);
    return tuple;
}
4

1 回答 1

2

因为这将被传递给另一个进程,所以仅腌制整数指针不会像您希望的那样工作。不同的进程使用不同的内存空间,因此他们看不到相同的东西。

因此,要回答您的问题,您应该腌制完整的对象并从接收端重建它们。

于 2011-05-14T06:07:57.567 回答