虚函数工作原理:
编译器处理虚函数的方法是:给每个对象添加一个隐藏成员中保存了一个指向函数地址数组的指针。这种数组称为虚函数表。虚函数表中存储了为类对象进行声明的虚函数的地址。例如,基类对象包含一个指针,该指针指向基类中所有虚函数的地址表。派生类对象将包含一个指向独立地址表的指针。如果派生类提供了虚函数的新定义,该虚函数表将保存新函数的地址;如果派生类没有重新定义虚函数,该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;
}
虚函数表解析
本文深入探讨了C++中虚函数的工作原理,通过示例详细解释了编译器如何使用虚函数表来实现多态性。当基类指针指向派生类对象时,通过虚函数表可以调用正确的函数实现。
3371

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



