对象内存布局 (13)——上一篇的纠正

简介: 下面来看看虚基类对对象内存布局的影响。虚基类的主要作用就是在所有的派生类中,保留且仅保留一份虚基类的suboject。 #include using namespace std; class Base { public: int m_base; Base():...

下面来看看虚基类对对象内存布局的影响。虚基类的主要作用就是在所有的派生类中,保留且仅保留一份虚基类的suboject。

#include <iostream>
using namespace std;

class Base
{
public:
    int m_base;
    Base():m_base(20){}
    virtual void vfBase_1()
    {
        cout << "This is in Base::vfBase_1()" << endl;
    }
    virtual void vfBase_2()
    {
        cout << "This is in Base::vfBase_2()" << endl;
    }
};

class Derived : public virtual Base
{
public:
    int m_derived;
    Derived():m_derived(10){}
    virtual void vfDerived()
    {
      cout << "This is in Derived::vfDerived()" << endl;
    }
    void vfBase_1()
    {
        cout << "This is in Derived::vfBase_1()" << endl;
    }
};

typedef void (*VFun)(void);

int main(void)
{
    Derived d;
    int **pVtab=NULL;
    pVtab=(int**)&d;
    cout << "The size of Base object = \t" << sizeof(Derived) << endl;
    cout << endl;
    cout<<"derived lst virtual function address: "<<(int*)(*((int*)(*(int*)&d) + 0))<<endl;
    cout<<"derived lst virtual function result: ";
    VFun pVF =(VFun)pVtab[0][0];
    pVF();
    cout<<endl;
    cout<<"derived 2nd virtual function address: "<<(int*)(*((int*)(*(int*)&d) + 1))<<endl;
    cout<<"derived 2nd virtual function result: ";
    pVF = (VFun)pVtab[0][1];
    pVF();
    cout<<endl;
    cout<<"virtual table end flags: "<<pVtab[0][2]<<endl;
    cout<<endl;

    cout<<"derived data member:";
    cout<<(int)*((int*)&d+1)<<endl;

    cout<<"base lst virtual function address: "<<(int*)pVtab[2][0]<<endl;
    cout<<"base lst virtual function result: ";
    pVF = (VFun)pVtab[2][0];
    pVF();
    cout<<endl;
    //转换为int*就代表虚函数的地址
    cout<<"base 2nd virtual function address: "<<(int*)(*((int*)(*((int*)&d+2)) + 1))<<endl;
    cout<<"base 2nd virtual function result: ";
    //转换为vFun代表虚函数的函数指针
    pVF = (VFun)(*((int*)(*((int*)&d+2)) + 1));
    pVF();
    cout<<endl;
    cout<<"virtual table end flags: "<<(*((int*)(*((int*)&d+2)) + 2))<<endl;
    cout<<endl;
    cout<<"base data member:";
    cout<<(int)pVtab[3]<<endl;
    return 0;
}

运行结果:

虚继承的内存分布图:

 

相关文章
|
存储 安全 算法
深入剖析JVM内存管理与对象创建原理
JVM内存管理,JVM运行时区域,直接内存,对象创建原理。
40 2
|
1月前
|
存储 算法 安全
【JVM】深入理解JVM对象内存分配方式
【JVM】深入理解JVM对象内存分配方式
29 0
|
6月前
|
存储 安全 程序员
浅谈内存管理及僵尸对象
浅谈内存管理及僵尸对象
33 0
|
1月前
|
Python
Python中如何判断两个对象的内存地址是否一致?
Python中如何判断两个对象的内存地址是否一致?
17 0
|
1月前
|
存储 安全 Java
【JVM】Java堆 :深入理解内存中的对象世界
【JVM】Java堆 :深入理解内存中的对象世界
53 0
|
2月前
|
存储 编译器 程序员
近4w字吐血整理!只要你认真看完【C++编程核心知识】分分钟吊打面试官(包含:内存、函数、引用、类与对象、文件操作)
近4w字吐血整理!只要你认真看完【C++编程核心知识】分分钟吊打面试官(包含:内存、函数、引用、类与对象、文件操作)
107 0
|
2月前
|
存储 缓存 算法
深入理解JVM - 对象分配内存
深入理解JVM - 对象分配内存
29 1
|
3月前
|
存储 缓存 算法
对象和数组并不是都是在堆上分配内存的
对象和数组并不是都是在堆上分配内存的
25 0
|
8月前
|
缓存 关系型数据库 MySQL
高性能内存对象缓存Memcached
高性能内存对象缓存Memcached案例
|
4月前
|
存储 Java
JVM(四):对象的内存布局
JVM(四):对象的内存布局