Boost.Python教程:暴露类的构造

26 篇文章 0 订阅

我们之前的示例没有任何显式构造函数。由于World被声明为普通结构,因此它具有隐式默认构造函数。 Boost.Python默认公开默认构造函数,这就是我们能够编写的原因

>>> planet = hello.World()


我们可能希望用非默认构造函数包装一个类。
让我们以前面的例子为基础:

struct World
{
    World(std::string msg): msg(msg) {} // added constructor
    void set(std::string msg) { this->msg = msg; }
    std::string greet() { return msg; }
    std::string msg;
};


这次World没有默认构造函数;
当库试图公开它时,我们以前的包装代码将无法编译。我们必须告诉class_ <World>我们想要公开的构造函数。

#include <boost/python.hpp>
using namespace boost::python;

BOOST_PYTHON_MODULE(hello)
{
    class_<World>("World", init<std::string>())
        .def("greet", &World::greet)
        .def("set", &World::set)
    ;
}


init <std :: string>()公开了接受std :: string的构造函数(在Python中,构造函数拼写为“”__init__“”)。

我们可以通过将更多init <...>传递给def()成员函数来公开其他构造函数。比方说,我们有另一个World构造函数接受两个双精度:

class_<World>("World", init<std::string>())
    .def(init<double, double>())
    .def("greet", &World::greet)
    .def("set", &World::set)
;


另一方面,如果我们不希望暴露任何构造函数,我们可以使用no_init代替:

class_<Abstract>("Abstract", no_init)


这实际上添加了一个__init__方法,它总是引发Python RuntimeError异常。
源代码:https://github.com/Lxxing/PythonStudy

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

道格拉斯范朋克

播种花生牛奶自留田

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值