我正在尝试使用pybind11实现一个抽象类。我所拥有的是:
基类
namespace VNCS
{
class BlendingField : public sofa::core::objectmodel::BaseObject
{
public:
SOFA_CLASS(BlendingField, sofa::core::objectmodel::BaseObject);
BlendingField() = default;
virtual ~BlendingField() = default;
virtual Real blending(const VNCS::Point_3 &p) const = 0;
};
} // namespace VNCS
和实施
namespace VNCS
{
namespace py
{
namespace module
{
void blendingField(pybind11::module &m);
}
class BlendingField : public VNCS::BlendingField
{
public:
SOFA_CLASS(VNCS::py::BlendingField, VNCS::BlendingField);
BlendingField();
~BlendingField() override;
VNCS::Real blending(const VNCS::Point_3 &p) const final;
};
} // namespace py
} // namespace VNCS
使用以下实现
PYBIND11_DECLARE_HOLDER_TYPE(T, sofa::core::sptr<T>, true);
VNCS::py::BlendingField::BlendingField()
: VNCS::BlendingField()
{
}
VNCS::py::BlendingField::~BlendingField()
{
}
VNCS::Real VNCS::py::BlendingField::blending(const VNCS::Point_3 &p) const
{
const std::array<double, 3> pyP{p[0], p[1], p[2]};
PYBIND11_OVERLOAD_PURE(VNCS::Real, /* Return type */
VNCS::BlendingField, /* Parent class */
blending, /* Name of function in C++ (must match Python name) */
pyP /* Argument(s) */
)
}
void VNCS::py::module::blendingField(pybind11::module &m)
{
pybind11::class_<VNCS::BlendingField, sofa::core::objectmodel::BaseObject, sofa::core::sptr<VNCS::BlendingField>>(
m, "BlendingFieldBase");
pybind11::class_<VNCS::py::BlendingField, VNCS::BlendingField, sofa::core::sptr<VNCS::py::BlendingField>>(
m, "BlendingField")
.def(pybind11::init(
[](pybind11::args & /*args*/, pybind11::kwargs &kwargs) { return new VNCS::py::BlendingField(); }))
.def("blending", &VNCS::BlendingField::blending);
}
如果创建一个Python文件,加载我的模块,创建一个^ {< CD1>},调用^ {CD2>},这是很好的,但是如果我用解释器(从另一个库中发生)调用C++的Python文件,得到一个指向混合字段的指针并尝试调用BuldEngy()。
terminate called after throwing an instance of 'std::runtime_error'
what(): Tried to call pure virtual function "VNCS::BlendingField::blending"
我不明白为什么会发生这种情况,因为调试C++方面清楚地表明我进入了VNCS::P::BrutnIdfield::混合实现。
这里发生了什么
目前没有回答
相关问题 更多 >
编程相关推荐