多个基类可以具有相同的虚拟方法吗?
Can multiple base classes have the same virtual method?
- 类 A 有一个纯虚拟方法
read()
- 类 B 有一个实现的虚拟方法
read()
- 我有一个继承 A 和 B 的 C 类
- 这能发生吗?
我试图实现的是两个基类 A 和 B 相互补充。
因此,C read()
方法实际上会调用 B 类read()
class A {
virtual int get_data() = 0;
void print() {
log(get_data());
}
}
class B {
virtual int get_data() {
return 4;
}
}
class C : public A, public B {
}
C my_class;
my_class.print(); // should log 4;
我不在我的电脑上,在接下来的几周内也不会有机会,所以我无法测试这个......但我正在设计架构,需要知道这是否可能,如果不可能。这怎么可能做到!
多个基类可以具有相同的虚拟方法吗?
- 这能发生吗?
是的。
所以 C read(( 方法实际上会调用类 B read((
这不会自动发生。base 的成员函数不会覆盖不相关的 base 的函数。
您可以向C
添加覆盖:
class C : public A, public B {
int get_data() override;
}
这将覆盖A::get_data
和B::get_data
。为了"实际调用类 B read((">,你确实可以进行这样的调用:
int C::get_data() {
return B::get_data();
}
或者......如果你没有宣布B::get_data
私人的,这是可能的。
如果您稍微更改层次结构,则可以重写另一个基中的函数而不显式委派派生。特别是,您需要一个共同的基础和虚拟继承:
struct Base {
virtual int get_data() = 0;
};
struct A : virtual Base {
void print() {
std::cout << get_data();
}
};
struct B : virtual Base {
int get_data() override {
return 4;
}
};
struct C : A, B {};
相关文章:
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- CPP 继承虚拟方法解析顺序
- 我是否应该在包含虚拟方法的类上使用'memcpy'?如果没有,如何替换它?
- 用c++中的纯虚拟方法抽象模板类
- 解决虚拟方法的歧义继承的两种方法
- 没有针对完全专用模板类的外联虚拟方法定义