#include <stdio.h>
class A
{
public:
A(){printf("cons A %d..\n",GetValue());}
virtual ~A(){}
virtual int GetValue(){return 0;}
};
class B:public A
{
public:
B(){}
virtual ~B(){}
private:
int GetValue(){return 123;}
};
int main()
{
A* a = new B;
printf("value %d..\n",a->GetValue());//返回123,
return 0;
}
这里派生类中的方法GetValue会被基类A中对应的方法覆盖,有人说这里类型不同,一个是public 一个private,其实没有关系。这个限制是在编译期间检查的,编译器不会因为不同的权限类型而不让重写方法。 另外如果在A的构造中直接调用虚函数,会访问A的方法,因为这个时候虚函数表还没有生成,会直接调用A的方法。虚函数表是在构造函数完成后生成的。
本文探讨了C++中虚函数的工作原理,特别是在派生类和基类之间的方法覆盖。通过一个具体示例,展示了如何在派生类中重写基类的虚函数,并解释了在构造函数中调用虚函数的特殊情况。
7935

被折叠的 条评论
为什么被折叠?



