正在重写c++中的虚拟方法
Overriding virtual method in c++
我有一个库,里面有很多类。我想修改某个类的一个虚拟方法的行为。我试着简化,我得到了什么,现在是:
#include <iostream>
using namespace std;
class B;
class A {
public:
A(B& b_) : b(b_) {};
B& b;
virtual void printon() {
cout << "Test virtual printon An" << endl;
}
void print() {
cout << "Test print An";
printon();
}
};
class B {
protected:
A a;
public:
B() : a(*this) {};
void print() {
a.print();
};
};
在我的程序中,我可以像这样使用它:
int main() {
B* b = new B();
b->print();
return 0;
}
实际上,方法a.printon()
是从一些其他代码和不同的条件调用的,并且不打印任何内容(它执行一些其他操作)。我需要重写这个方法来做其他事情,例如打印"test2"。
我可以创建一个派生类newA
:
class newA : public A {
public:
newA(B& b_) : A(b_) {};
virtual void printon() {
cout << "Test printon newA"<< endl;
}
};
我不确定下一步该怎么办。也许创建一个类newB
,比如:
class newB : public B {
public:
newB() : B() {};
};
但是如何使A
型的B.a
表现得像newA
型呢?
B
按值包含A
,这排除了多态性的使用(如果您试图将newA
设置到A
对象中,则会得到对象切片。如果您希望B
能够使用A
的派生版本,则需要通过(智能)指针存储它。
相关文章:
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- CPP 继承虚拟方法解析顺序
- 我是否应该在包含虚拟方法的类上使用'memcpy'?如果没有,如何替换它?
- 用c++中的纯虚拟方法抽象模板类
- 解决虚拟方法的歧义继承的两种方法
- 没有针对完全专用模板类的外联虚拟方法定义