我可以使用覆盖非虚拟方法的方法吗?
Can i use a method overriding a non-virtual method?
我试图用C++来理解一点。如果类 A 有一个非虚拟方法,而扩展 A 的类 B 覆盖了该方法,我可以创建 B 的实例并以某种方式使用 B 中定义的方法吗?是否有覆盖非虚拟方法的意义?
是否有覆盖非虚拟方法的意义?
您实际上并没有覆盖,但这是行为,即
B* b = new B();
A* a = new B();
b->method(); //Calls B's method
a->method(); // Calls A's method
因此,指针/引用类型确定调用的方法。
我可以创建 B 的实例并以某种方式使用 B 中定义的方法吗?
是的。指针/引用类型必须是 B 类型(请参阅前面的示例)。
如果不将method
声明为 virtual
,则无法覆盖它,但可以隐藏它。
如果B
继承自A
,并重新定义A
中定义的方法,则B
的新实例将调用B
的版本。但是,如果该方法不是虚拟的,则没有多态行为,因此如果B
的实例被引用为A
,则该方法将A
。例如:
struct A {
void foo () { std::cout << "A::foo" << std::endl; }
};
struct B : public A {
void foo () { std::cout << "B::foo" << std::endl; }
};
B b;
b.foo();
A *a = &b;
a->foo();
上面代码的输出将是:
B::foo
A::foo
但是,如果foo
方法是虚拟的,那么B::foo
将被打印两次。
如果函数未virtual
则变量的类型也决定了调度哪个实现:
#include <iostream>
using namespace std;
struct A {
void f() { cout << "A" << endl; }
};
struct B : public A {
void f() { cout << "B" << endl; }
};
int main(int args, char** argv) {
B b;
A& a = b;
b.f();
a.f();
return 0;
}
- 否,没有覆盖类 A 中的非虚拟方法的机制。
- 是的,您可以使用范围解析运算符 A::methodName 在 B 中重载的类 A 中的非虚拟方法
相关文章:
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 从纯虚拟类 (A) 派生的指针无法访问来自纯类 (B) 的重载方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 派生类中纯虚拟基方法的专业化
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- 使用回调函数从构造函数调用虚拟/派生方法的替代方法?
- 如何调用孩子的方法:虚拟关键字不起作用