4
CPP:升压Python对象生命周期
#include <boost/python.hpp>
using namespace boost;
using namespace boost::python;
struct Foo
{
virtual ~Foo() {}
virtual void Print() = 0;
};
struct FooWrap : Foo, wrapper<Foo>
{
void Print()
{
this->get_override("Print")();
}
};
void ProcessFoo(Foo *obj) { obj->Print(); }
BOOST_PYTHON_MODULE(hello_ext)
{
class_<FooWrap, boost::noncopyable>("Foo")
.def("Print", pure_virtual(&Foo::Print));
def("ProcessFoo", &ProcessFoo);
}
蟒蛇:
import hello_ext
class NewFoo(hello_ext.Foo):
def Print(self):
print 'Print call'
hello_ext.ProcessFoo(NewFoo())
一切正常,没有从ProcessFoo
通话Print call
文本。但是,我要全部通过指针存储ProcessFoo
,如:
std::vector<Foo*> data;
void ProcessFoo(Foo *obj) { data.push_back(obj); obj->Print(); }
后从函数指针退出变得无效,我不能从矢量使用它。使指针的寿命更长的最佳方法是什么?使用共享指针或告诉python不要删除对象(如果它删除它)?
你有'Foo&'在'std :: pair'吗? – 2016-03-15 19:56:24
是的,你可以拥有。它不过是一个“指针”。但是您必须确保在删除后不访问对象,这是通过增加和存储引用(对象)来确保的。 – Sven 2016-03-16 09:06:32