简而言之,在免费存储上分配包装器,并使用
manage_new_object
result convert将所有权转移到Python对象。这将导致Boost。Python在构造Python对象时复制指针,而不是复制指针对象。
C++对象嵌入到Python对象中。这是
HeldType
通过公开类时提供
class_
,默认为公开的C++类型。通常,在公开函数时,可以使用
CallPolicy
实例。特别是,使用
return_value_policy
带有的CallPolicy
管理新对象
ResultConverterGenerator
允许嵌入类型为指针,Python对象将管理所有权。
以下函数可用于将对象的所有权转移到Python,而无需复制指针对象:
template <typename T>
boost::python::object transfer_to_python(T* t)
{
std::unique_ptr<T> ptr(t);
namespace python = boost::python;
typename python::manage_new_object::apply<T*>::type converter;
python::handle<> handle(converter(*ptr));
ptr.release();
return python::object(handle);
}
示例用法:
void appendFoosToList(boost::python::list& list)
{
for (const Foo* foo : m_foos)
{
list.append(transfer_to_python(new FooWrapper(*foo)));
}
}
下面是一个完整的示例
demonstrating
这种方法:
#include <iostream>
#include <boost/python.hpp>
class spam
{
public:
spam() { std::cout << "spam(): " << this << std::endl; }
spam(const spam&)
{
std::cout << "spam(const spam&): " << this << std::endl;
}
~spam() { std::cout << "~spam(): " << this << std::endl; }
};
template <typename T>
boost::python::object transfer_to_python(T* t)
{
std::unique_ptr<T> ptr(t);
namespace python = boost::python;
typename python::manage_new_object::apply<T*>::type converter;
python::handle<> handle(converter(*ptr));
ptr.release();
return python::object(handle);
}
void append_to_list(boost::python::list& list)
{
list.append(transfer_to_python(new spam()));
}
BOOST_PYTHON_MODULE(example)
{
namespace python = boost::python;
python::class_<spam>("Spam", python::no_init);
python::def("append_to_list", &append_to_list);
}
交互式用法:
>>> import example
>>> spams = []
>>> example.append_to_list(spams)
spam(): 0x25cbd90
>>> assert(type(spams[0]) is example.Spam)
>>> del spams
~spam(): 0x25cbd90