python - C++ 嵌入式解释器和对象

python - c++ embedded interpreter and objects

我有一个简单的 C++ 程序,它启动一个嵌入式 python 解释器,导入一个模块并实例化一个在该模块中定义的 class。

想明白为什么python对象的地址(从python的角度)和C++对象的地址不一样

python 实例和该实例的 c++ 视图有何不同的内存地址?

这是一些工作代码,使用 pybind11:

#include <iostream>
#include <pybind11/pybind11.h>
#include <pybind11/embed.h>

using namespace std;
namespace py = pybind11;

int main()
{
    {
        py::scoped_interpreter guard{};
        py::module m = py::module::import("code");
        py::object o = m.attr("SomeClass")();
        cout << "[C++   ] object lives in " << &o << endl;
    }
    return 0;
}
def message_from_python(*args):
    print('[PYTHON]', *args)


class SomeClass:
    def __init__(self):
        message_from_python(self, 'being created')

    def __del__(self):
        message_from_python(self, 'being deleted')

编译、执行和标准输出:

$ g++ -O3 -Wall -std=c++14 `python3 -m pybind11 --includes` code.cc -o code -lpython3.6m
$ ./code
[PYTHON] <code.SomeClass object at 0x7fb6926f1da0> being created
[C++   ] object lives in 0x7fffbed02588                   
[PYTHON] <code.SomeClass object at 0x7fb6926f1da0> being deleted

如果我们快速看一下 py::object 在其声明 here 中的构成,您会发现 class 将 PyObject * 作为受保护的成员(继承自 py::handle)。该指针包含您看到的从 python 端打印出来的地址。如果您可以访问它,您会看到

cout << o.mptr << endl;

生成与 python shell 相同的地址。