关于C++|关于C++ 多重继承下虚表结构的问题
前言
昨天写一个项目时遇到一个很诡异的现象 如下代码所示:
class ParentA {public : int a=0x123456; virtual void vFunParentA(){std::cout << "vFunParentA" << std::endl; }}; class ParentB {public: int b = 0x456; virtual void vFunParentB() {std::cout<<"vFunParentB"vFunParentA(); getchar(); }
现在执行后我们的预期输出为
vFunParentB但实际输出:
vFunParentA
vFunParentA当时百思不得其“姐”,最后发现是自己对多重继承下的虚表内存结构不够了解。
vFunParentA
博主另一外一篇关于虚表的:
c-15 c++虚表
在多重继承下
Child
内存结构应该是如下结构:文章图片
由于我们使用
void *
类型强转为ParentB
,ParentA
返回的指针地址依然是ParentA
,而没有做内存偏移计算.如下图所示:文章图片
当我们不适用
void*
强转后编译器会帮我进行偏移计算会迫使ParentB
偏移8字节,从而使pParentB
指向正确的内存虚表。文章图片
在单一继承下不会出现这类问题,我们最后看下本例中的内存结构:
文章图片
文章图片
文章图片
文章图片
【关于C++|关于C++ 多重继承下虚表结构的问题】到此这篇关于关于C++ 多重继承下虚表结构的问题的文章就介绍到这了,更多相关C++ 多重继承虚表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- 四首关于旅行记忆的外文歌曲
- 醒不来的梦
- opencv|opencv C++模板匹配的简单实现
- 关于自我为中心的一点感想
- 「按键精灵安卓版」关于全分辨率脚本的一些理解(非游戏app)
- C语言学习|第十一届蓝桥杯省赛 大学B组 C/C++ 第一场
- 关于Ruby的杂想
- 关于读书的思考
- 关于this的一些问题(1)