虚函数表
- 在C++类中,一旦成员函数中有虚函数,这个类中就会多一个虚函数表指针,这个指针指向一个虚函数表,表里记录了这个类中所有的虚函数,当这个类被继承,它的子类中也会有一个虚函数表(不管子类中有没有虚函数),如果子类的成员函数中有函数签名与父类的虚函数一样就会用子类中的函数替换它,在虚函数表中的位置,这样就达到了覆盖的效果
- 当通过类指针或应用调用函数时,会根据对象中实际的虚函数表记录来调用函数,这样就达到了多态的效果
#include <iostream>
using namespace std;
class Base
{
public:
virtual void f1(void)
{
cout << "f1函数" << endl;
}
};
class Test:public Base
{
public:
void f2(void)
{
cout << "f2函数" << endl;
}
virtual void f3(void)
{
cout << "f3函数" << endl;
}
static void f4(void)
{
cout << "f4函数" << endl;
}
virtual void f5(void)
{
cout << "f5函数" << endl;
}
};
typedef void (*funcp)(void);
int main()
{
Test* p = new Test;
int* p1 = (int*)*(int*)p;//p1指向虚函数表的地址(前4个字节保存了虚函数表的地址)
((funcp)(*(p1)))();//调用虚函数表中的第1个函数,运行结果:f1函数
//((funcp)(*(p1+1)))();//调用虚函数表中的第2个函数,运行结果:段错误
((funcp)(*(p1+2)))();//调用虚函数表中的第3个函数,运行结果:f3函数
//((funcp)(*(p1+3)))();//调用虚函数表中的第4个函数,运行结果:段错误
((funcp)(*(p1+4)))();//调用虚函数表中的第5个函数,运行结果:f5函数
cout << *(p1) << endl;//运行结果4197140或其他
cout << *(p1+1) << endl;//运行结果0
cout << *(p1+2) << endl;//运行结果4197184或其他
cout << *(p1+3) << endl;//运行结果0
cout << *(p1+4) << endl;//运行结果4197228或其他
}