多态实现原理-虚函数表内存分析及虚基类表的内存分析

本文探讨了C++中多态实现的原理,包括虚函数表和虚基类表的内存分析。通过对虚函数表的解释,说明了如何通过基类指针调用派生类的虚函数,以及派生类如何融合并覆盖基类的虚函数表。同时,介绍了虚基类表在解决虚继承中多继承变量二义性问题的角色,以及如何通过虚基类表找到派生类中虚基类成员的内存位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

看了深入探索C++对象模型后的一些感悟

1:虚函数表内存分析

每一个类对象的内存由nostatic data member和指向虚数表的指针之和决定。

class A{

private:

int a;

virtual void fun1();

virtual void fun2();

};

calss B: public A{

void fun2();

virtual void fun3();};

A a;

B b; A *p=&b;

A的指针指向派生类B中的基类部分,指针a无法调用B中的成员,唯一的例外是指向虚函数表的指针。即基类指针可以通过指向虚函数表的指针来调用派生类的虚函数。

继承后,派生类的虚函数表会和基类的虚函数表相融合,若存在override则在派生类的虚函数表中就覆盖掉;

像上面的例子:

一个A类的对象:

int a;

vptr;

这个vptr是指向A虚函数表的指针,A虚函数表:里存放着指向虚函数的指针,一个是指向fun1的,一个是指向fun2的

一个B类的对象:

int a,

vptr:

这个vptr是指向B的虚函数表指针,B的虚函数表与A的想融合,相同则覆盖:fun1,fun2,fun3;

这样当p=&b时,p->fun2是派生类中的fun2;当p=&a时是调用基类中的fun2

2:虚基类表

与虚函数表类似,虚继承中,一个类除了有Nonstaic data member还有指向虚基类表的指针;虚继承是避免了多继承中的变量二义性;

class A{int a;}

class B :public virtual A{int b;}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值