C++ 通过接口使用从其他几个类继承的类



我正在学习C++,我对多重继承和接口类感到困惑。

我想要一个从其他几个类继承的类。另外,我想通过接口使用该派生类。所以我想,派生类应该扩展基类,派生接口应该扩展基接口。我会用其他语言这样做,但我认为C++不是那样工作的。

这是我认为应该有效的代码:

#include <iostream>
using std::cout;
using std::endl;
class
Base1Itf
{
public:
virtual void blue() = 0;
};
class
Base1Abs
:
public Base1Itf
{
public:
void blue()
{
cout << "blue" << endl;
}
};
class
DerivedItf
:
public Base1Itf
{
public:
virtual void red() = 0;
};
class
Derived
:
public Base1Abs,
public DerivedItf
{
public:
void red()
{
cout << "red" << endl;
}
};
int main()
{
DerivedItf* d = new Derived();
d->red();
d->blue();
delete d;
return 0;
}

这是我得到的编译器错误:

src/test.cpp: In function ‘int main()’:
src/test.cpp:49:30: error: invalid new-expression of abstract class type ‘Derived’
DerivedItf* d = new Derived();
^
src/test.cpp:35:2: note:   because the following virtual functions are pure within ‘Derived’:
Derived
^~~~~~~
src/test.cpp:10:16: note:       virtual void Base1Itf::blue()
virtual void blue() = 0;
^~~~

在示例中,仅实现了一个基类,但还会有更多基类。

我做错了什么?谢谢。


编辑

如果我删除 Base1Itf 的 Base1Abs 继承以避免钻石问题,编译器会显示相同的错误。

这是C++众所周知的钻石问题。这是您解决它的方法:

#include <iostream>
using std::cout;
using std::endl;
class Base1Itf {
public:
virtual void blue() = 0;
virtual ~Base1Itf() { }
};
class Base1Abs : virtual public Base1Itf {
public:
void blue() override {
cout << "blue" << endl;
}
virtual ~Base1Abs() { }
};
class DerivedItf : virtual public Base1Itf {
public:
virtual void red() = 0;
virtual ~DerivedItf() { }
};
class Derived : public Base1Abs, public DerivedItf {
public:
void red() override {
cout << "red" << endl;
}
virtual ~Derived() { }
};
int main() {
DerivedItf* d = new Derived();
d->red();
d->blue();
delete d;
return 0;
}

还建议在继承中使用虚拟析构函数。

你看,这里发生的事情是类Base1AbsDerivedItf都继承了blue的副本。现在,当您从这 2 个类继承另一个类Derived时,该类继承了blue的 2 个副本,然后编译器开始想知道要调用哪个副本。因此,您实际上继承了 2 个类,导致只继承了blue的一个副本

最新更新