虚函数工作原理:
编译器处理虚函数的方法是:给每个对象添加一个隐藏成员中保存了一个指向函数地址数组的指针。这种数组称为虚函数表。虚函数表中存储了为类对象进行声明的虚函数的地址。例如,基类对象包含一个指针,该指针指向基类中所有虚函数的地址表。派生类对象将包含一个指向独立地址表的指针。如果派生类提供了虚函数的新定义,该虚函数表将保存新函数的地址;如果派生类没有重新定义虚函数,该vtbl将保存函数原始版本的地址。如果派生类定义了新的虚函数,则该函数的地址也将被添加到vtbl中
无继承时虚函数表:
#include <iostream>
using namespace std;
class Base
{
public:
virtual void fun()
{
cout << "1" << endl;
}
virtual void foo()
{
cout << "2" << endl;
}
virtual void fcn()
{
cout << "3" << endl;
}
};
int main()
{
Base obj;
Base *b = &obj;
b->fun();
b->foo();
b->fcn();
return 0;
}
虚表单一继承:
#include <iostream>
using namespace std;
class Base
{
public:
virtual void funA()
{
cout << "1" << endl;
}
virtual void foo()
{
cout << "2" << endl;
}
virtual void fcn()
{
cout << "3" << endl;
}
};
class Derived :public Base
{
public:
virtual void fun()
{
cout << "4" << endl;
}
virtual void foo()
{
cout << "5" << endl;
}
virtual void fcn()
{
cout << "6" << endl;
}
};
int main()
{
Derived Dobj;
Base *p = &Dobj;
p->funA();
p->foo();
p->fcn();
return 0;
}