• 【c++内存分布系列】虚基类表


      虚基类表相对于虚函数表要稍微难理解些,故单独提出来。

      虚函数表是在对象生成时插入一个虚函数指针,指向虚函数表,这个表中所列就是虚函数。

      虚基类表原理与虚函数表类似,不过虚基类表的内容有所不同。表的第一项表示派生类对象指针相对于虚基类表指针的偏移,从第二项开始表示各个基类地址相对于虚基类表指针的偏移。

      程序

    #include <cstdio>
    
    class A
    {
    public:
        int a;
        int aa;
        virtual void vfuna(){};
    };
    
    class B
    {
    public:
        int b;
        int bb;
        virtual void vfunb(){};
    };
    
    class C: virtual public A,virtual public B
    {
    public:
        int c;
        int cc;
        void vfuna(){};
    };
    
    
    int main(int argc, char** argv)
    {
        printf("%d
    ", sizeof(C));
    
        C c;
        c.a = 0xaaaaaaaa;
        c.aa = 0xbbbbbbbb;
        c.b = 0xdddddddd;
        c.bb = 0xeeeeeeee;
        c.c = 0x11111111;
        c.cc = 0x22222222;
        C* pc = &c;
        printf("%08x
    ", pc);
    }

      windows输出:

    36
    0034f834

      查看对象c内存0x34f834:

    0034F834 60 
    0034F835 57 
    0034F836 1D 00 11 11 11 
    0034F83B 11 22  
    0034F83D 22 22  
    0034F83F 22 58 57  
    0034F842 1D 00 AA AA AA  
    0034F847 AA 
    0034F848 BB BB BB BB 4C 
    0034F84D 57 
    0034F84E 1D 00 DD DD DD 
    0034F853 DD EE
    0034F855 EE
    0034F856 EE  
    0034F857 EE 

      查看虚基类表0x001d5760:

    C::`vbtable':
    001D5760 00 00 add byte ptr [eax],al
    001D5762 00 00 add byte ptr [eax],al
    001D5764 0C 00 or al,0
    001D5766 00 00 add byte ptr [eax],al
    001D5768 18 00 sbb byte ptr [eax],al
    001D576A 00 00 add byte ptr [eax],al
    001D576C 00 00 add byte ptr [eax],al
    001D576E 00 00 add byte ptr [eax],al

      得派生类对象指针相对于虚基类表指针的偏移0,基类A地址相对于虚基类表指针的偏移12,基类B地址相对于虚基类表指针的偏移24。查看偏移12位内容为0x001d5758。其指向地址内容:

    C::`vftable':
    001D5758 91 xchg eax,ecx
    001D5759 10 1D 00 00 00 00 adc byte ptr ds:[0],bl
    001D575F 00 00 add byte ptr [eax],al

    C::vfuna:
    001D1091 E9 AA 05 00 00 jmp C::vfuna (1D1640h)

      偏移24位内容为0x0014574c,其指向地址内容为:

    C::`vftable':
    001D574C 0A 10 or dl,byte ptr [eax]
    001D574E 1D 00 00 00 00 sbb eax,0
    001D5753 00 F8 add al,bh

    B::vfunb:
    001D100A E9 F1 05 00 00 jmp B::vfunb (1D1600h)

      验证一个为虚基类A内容,一个为虚基类B内容。

  • 相关阅读:
    openstack-ntp时间同步服务
    如何将icon图标库引入自己的项目中
    微信小程序实现滑动tab切换和点击tab切换并显示相应的数据(附源代码)
    微信小程序分享至朋友圈的方法
    微信小程序--分享功能
    mpvue-新建页面、页面跳转、自适应单位
    微信小程序mpvue-动态改变navigationBarTitleText值
    mpvue中使用flyjs全局拦截
    H5 布局 -- 让容器充满屏幕高度或自适应剩余高度
    使用mpvue开发小程序如何定义全局变量
  • 原文地址:https://www.cnblogs.com/budapeng/p/3305790.html
Copyright © 2020-2023  润新知