c – 虚函数表偏移量

c – 虚函数表偏移量,第1张

概述我想问一下,一个类的虚函数表的偏移量取决于什么?我的意思是,从我读过的内容来看它至少取决于编译器,但它是否因类不同而有所不同? 编辑:按偏移量我的意思是表格相对于所有者对象地址的位置. 编辑:示例代码: void **vtable = *((void***)(((char*)object)+offset));int **ivtable=(int **)vtable;void* firstF 我想问一下,一个类的虚函数表的偏移量取决于什么?我的意思是,从我读过的内容来看它至少取决于编译器,但它是否因类不同而有所不同?

编辑:按偏移量我的意思是表格相对于所有者对象地址的位置.

编辑:示例代码:

voID **vtable = *((voID***)(((char*)object)+offset));int **ivtable=(int **)vtable;voID* firstFunction = (voID*) ivtable[0];
解决方法 肯定有依赖于确切的类.

请记住,C具有多重继承(MI). MI的结果是单个对象可能具有多个基础子对象.那些当然不能在同一个地址.这也意味着一些基础子对象实际上并不以相对偏移0开始.

现在,这个MI在vtable中引入了相当多的复杂性:你在不同的偏移量下从多个基础继承函数.因此,为MI类使用不同的vtable布局是很常见的.

在相关的说明中,MI还意味着并非每个指向对象的指针实际上都是指向该对象起点的指针.指向Derived对象的SecondBase *指针很可能被sizeof(FirstBase)偏移,即指向Derived对象中间的某个位置.

总结

以上是内存溢出为你收集整理的c – 虚函数表偏移量全部内容,希望文章能够帮你解决c – 虚函数表偏移量所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1212712.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存