-
对于普通继承,基类子对象始终位于派生类对象的前面(也即基类成员变量始终在派生类成员变量的前面),而且不管继承层次有多深,它相对于派生类对象顶部的偏移量是固定的。请看下面的例子:
-
obj_a、obj_b、obj_c、obj_d 的内存模型如下所示
A 是最顶层的基类,在派生类 B、C、D 的对象中,A 类子对象始终位于最前面,偏移量是固定的,为 0。b1、b2 是派生类 B 的新增成员变量,它们的偏移量也是固定的,分别为 8 和 12。c1、c2、d1、d2 也是同样的道理。
-
前面我们说过,编译器在知道对象首地址的情况下,通过计算偏移来存取成员变量。对于普通继承,基类成员变量的偏移是固定的,不会随着继承层级的增加而改变,存取起来非常方便。
而对于虚继承,恰恰和普通继承相反,大部分编译器会把基类成员变量放在派生类成员变量的后面,这样随着继承层级的增加,基类成员变量的偏移就会改变,就得通过其他方案来计算偏移量。下面我们来一步一步地分析虚继承时的对象内存模型。
-
1) 修改上面的代码,使得 A 是 B
C++虚继承下的内存模型
最新推荐文章于 2025-02-04 04:49:38 发布
本文探讨了C++中的虚继承对对象内存布局的影响。与普通继承不同,虚继承导致基类成员变量位于派生类对象的后面,且其偏移量随继承层次增加而变化。文章通过实例分析了虚基类在派生类内存中的位置,并指出编译器在计算虚继承的偏移量时存在多种策略。



最低0.47元/天 解锁文章
1831

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



