本文研究单继承情况下,c++对象的虚函数表的具体情况。
假设有两个类A,B, 其中B由A派生出来,A含有虚函数fun1,B含有虚函数fun2。
测试的代码如下:
#include<iostream>
using namespace std;
class A
{
public:
virtual void fun1()
{
cout<<"A::fun1"<<endl;
} }; class B:public A
{
public:
virtual void fun2()
{
cout<<"B::fun2"<<endl;
} virtual void fun1()
{
cout<<"B::fun1"<<endl;
} }; typedef void (*Fun)(void);
int main(int argc, char* argv[])
{
B b; cout<<"虚函数表指针的地址为:"<<(int *)(&b)<<endl;
cout<<"虚函数表的地址为:"<<*(int *)(&b)<<endl;
cout<<"第一个虚函数fun1的地址为:"<<(int *) *(int *)(&b)<<endl; Fun fun1=( Fun) ( *(int *) *(int *)(&b));
fun1(); cout<<"第二个虚函数fun2的地址为:"<< (int *) ((int *) (*(int *)(&b))+1) << endl;
Fun fun2=(Fun) (* ((int *) (*(int *)(&b))+1));
fun2();
return 0;
}
运行结果:
虚函数表指针的地址为:0xbfa9a77c
虚函数表的地址为:134515592
第一个虚函数fun1的地址为:0x8048b88
B::fun1
第二个虚函数fun2的地址为:0x8048b8c
B::fun2
测试代码说明:
虚函数表指针 (int *)(&b)
虚函数表地址 *(int *)(&b)
虚函数表的第一个元素,也就是指向fun1的指针 (int * )(*(int *)(&b))
虚函数表的第二个元素,也就是指向fun2的指针 (int * )(*(int *)(&b)) + 1)
在这种单继承的情况下,如果有虚函数表,那么只有一个虚函数表,并且按照虚函数声明的顺序顺序排列,派生类的虚函数紧接着基类的虚函数排列,类B的虚函数表结果如下图所示: