【发布时间】:2018-08-01 05:58:02
【问题描述】:
我有一个模块,其中公开了两个 C++ 类,它们都有一个方法 foo():
struct MyClassA{
void foo() { std::cout << "MyClassA::foo()" << std::endl; }
};
struct MyClassB{
void foo() { std::cout << "MyClassB::foo()" << std::endl; }
};
BOOST_PYTHON_MODULE(my_module){
class_<MyClassA>("MyClassA", init<>()).def("foo", &MyClassA::foo);
class_<MyClassB>("MyClassB", init<>()).def("foo", &MyClassB::foo);
}
在 Python 中,我创建了一个派生自两个类的类:
from my_module import MyClassA, MyClassB
class Derived(MyClassA, MyClassB):
def foo(self):
super().foo() # should be unnessessary - doesn't work anyway
a = MyClassA()
a.foo() # works
b = MyClassB()
b.foo() # works
d = Derived()
d.foo() # only prints 'MyClassA::foo()'
现在我希望d.foo() 致电MyClassA.foo() 和MyClassB.foo()。但是虽然Derived.mro() 看起来不错:
[<class '__main__.Derived'>, <class 'my_module.MyClassA'>, <class 'my_module.MyClassB'>, <class 'Boost.Python.instance'>, <class 'object'>]
.. 只有MyClassA.foo() 被调用。
如何让 C++ 方法调用它们的 super() 方法?这对__init__() 也有效吗?
【问题讨论】:
标签: python c++ multiple-inheritance super boost-python