我想不出在以下情况下会发生什么:C++多重继承
class MBase {
public:
MBase(int) {}
virtual char* vf() const = 0;
virtual ~MBase() {}
};
class D1 : public MBase { //NOT VIRTUAL!!!
public:
D1() : MBase(1) {}
char* vf() const { return "D1"; }
};
class D2 : virtual public MBase {
public:
D2() : MBase(2) {}
char* vf() const { return "D2"; }
};
class Bottom : public D1, public D2 {
public:
char* vf() const { return "Bottom"; }
}
Base* b = new Bottom();
在D1和D2从MBASE几乎继承了钻石的原始定义,但这里只有一个。我们是否仍然在Bottom对象中有两个单独的子对象,因此最后一行不能编译,因为编译器不知道要使用哪个子对象?
你*尝试了吗? – 2012-04-14 17:04:51