#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的方法。虚函数表是在构造函数完成后生成的。