我有一个方法(或函数),它返回对多态对象列表的引用:
class A {
};
class B : public A {
};
std::list<boost::shared_ptr<A> >& getList();
如何在 boost::python 中公开这样的函数,以便在 python 中迭代列表时,我会看到不同类型的A
s 和B
s ?
我有一个方法(或函数),它返回对多态对象列表的引用:
class A {
};
class B : public A {
};
std::list<boost::shared_ptr<A> >& getList();
如何在 boost::python 中公开这样的函数,以便在 python 中迭代列表时,我会看到不同类型的A
s 和B
s ?
首先,确保你的类确实是多态的(即它们至少有一个虚函数或虚析构函数)。您上面的示例没有,但我确信您的真实用例确实如此。没有它,Boost.Python 的基于 RTTI 的多态机制将无法工作。
然后,如果您使用 Boost.Python 公开了这两个类并shared_ptr
为它们注册了转换器:
#include <boost/python.hpp>
namespace bp = boost::python;
BOOST_PYTHON_MODULE(example) {
bp::class_<A >("A");
bp::register_ptr_to_python< boost::shared_ptr<A> >();
bp::class_< B, bp::bases<A> >("B");
bp::register_ptr_to_python< boost::shared_ptr<B> >();
}
...这就是您需要做的所有事情,以确保 Python 只看到最派生的类型。没有必要做任何特别的事情来确保在可能的情况下A
被投射到B
。
这仍然留下了如何包装返回容器的函数的问题。最简单的可能是使用 Boost.Python 附带的索引套件:
http://www.boost.org/doc/libs/1_49_0/libs/python/doc/v2/indexing.html
网络上还有其他选项(包括索引套件的“版本 2”,它在许多方面都更好,但不包含在 Boost.Python 中),但对于简单的问题,这可能是最方便的。