C++中继承的内存分布
2012-02-08 21:10
281 查看
class Base
{
public:
int m_base;
};
class DerivedA: public Base
{
public:
int m_derivedA;
};
class DerivedB: public Base
{
public:
int m_derivedB;
};
class DerivedC: public DerivedA, public DerivedB
{
public:
int m_derivedC;
};
类结构图:
内存分布图:
DerivedC:
DerivedA::m_base
m_derivedA
DerivedB::m_base
m_derivedB
m_derivedC
====================================================
如果DerivedB 和 DerivedC 都是虚继承 , 即 virtual public Base
这时内存布局:
DerivedC:
objDerivedA::vbptr
objDerivedA::m_derivedA
objDerivedB::vbptr
objDerivedB::m_derivedB
m_derivedC
m_base 只有一份
类似于这个:
=================================================================
Base, DerivedA, DerivedB 各增加一个虚函数
则内存布局为:
DerivedB:
DerivedB::vfptr
DerivedB::vbptr
DerivedB::m_derivedB
Base::vfptr
Base::m_base
DerivedC:
DerivedA::vfptr 04
DerivedA::vbptr 08
DevivedA::m_derivedA 0C
DevivedB::vfptr 10
DerivedB::vbptr 14
DerivedB::m_derivedB 18
m_derivedC 1C
Base::vfptr 20
m_base 24
如果是这样呢?
class A{}
class B1: classA{virtual fun()}
class B2: virtual public classA{virtual fun()}
class C: public B1,public B2{} 这样Virtual继承起不到作用, C还是有两个内嵌A对象,就是有两个m_base
Class C:
DerivedA::vfptr
DerivedA::m_base
DerivedA::m_derivedA
DerivedB::vfptr
DerivedB::vbptr
DerivedB::m_derivedB
m_derivedC
DerivedB::m_base
总结:
先基类元素后继承类元素
有虚函数只是增加vfptr;继承的类如果有增加虚函数,向vtable增加函数指针
虚继承增加vbptr,注意:虚基类元素排在最后(这个是和 先基类后继承 不同之处)
注意上面,凡是打上了vbptr的类, DerivedB::m_base都被打到了最后。
vfptr在vbptr之前
转载于:http://www.cnblogs.com/DylanWind/archive/2009/01/12/1373919.html
{
public:
int m_base;
};
class DerivedA: public Base
{
public:
int m_derivedA;
};
class DerivedB: public Base
{
public:
int m_derivedB;
};
class DerivedC: public DerivedA, public DerivedB
{
public:
int m_derivedC;
};
类结构图:
内存分布图:
DerivedC:
DerivedA::m_base
m_derivedA
DerivedB::m_base
m_derivedB
m_derivedC
====================================================
如果DerivedB 和 DerivedC 都是虚继承 , 即 virtual public Base
这时内存布局:
DerivedC:
objDerivedA::vbptr
objDerivedA::m_derivedA
objDerivedB::vbptr
objDerivedB::m_derivedB
m_derivedC
m_base 只有一份
类似于这个:
=================================================================
Base, DerivedA, DerivedB 各增加一个虚函数
则内存布局为:
DerivedB:
DerivedB::vfptr
DerivedB::vbptr
DerivedB::m_derivedB
Base::vfptr
Base::m_base
DerivedC:
DerivedA::vfptr 04
DerivedA::vbptr 08
DevivedA::m_derivedA 0C
DevivedB::vfptr 10
DerivedB::vbptr 14
DerivedB::m_derivedB 18
m_derivedC 1C
Base::vfptr 20
m_base 24
如果是这样呢?
class A{}
class B1: classA{virtual fun()}
class B2: virtual public classA{virtual fun()}
class C: public B1,public B2{} 这样Virtual继承起不到作用, C还是有两个内嵌A对象,就是有两个m_base
Class C:
DerivedA::vfptr
DerivedA::m_base
DerivedA::m_derivedA
DerivedB::vfptr
DerivedB::vbptr
DerivedB::m_derivedB
m_derivedC
DerivedB::m_base
总结:
先基类元素后继承类元素
有虚函数只是增加vfptr;继承的类如果有增加虚函数,向vtable增加函数指针
虚继承增加vbptr,注意:虚基类元素排在最后(这个是和 先基类后继承 不同之处)
注意上面,凡是打上了vbptr的类, DerivedB::m_base都被打到了最后。
vfptr在vbptr之前
转载于:http://www.cnblogs.com/DylanWind/archive/2009/01/12/1373919.html
相关文章推荐
- C++浅析——继承类内存分布和虚析构函数
- C++继承、多重继承与虚基类 继承、多重继承时对象内存分布
- C++ 多重继承和虚继承 内存分布
- C++浅析——继承类内存分布和虚析构函数
- 3.4 C++四种继承关系中内存分布
- C++多重继承虚表的内存分布
- C++内存分布之菱形继承(无虚函数)
- C++内存分布之单继承和多继承(无虚函数)
- 【c++】深入剖析虚拟继承与各种继承关系中派生类内成员内存分布情况及虚基类表的内容
- C++对象内存分布(2) - 菱形继承(non virtual)
- 【C++】虚函数和虚继承的内存分布情况
- c++ 虚拟继承,gcc内存分布情况
- c++多重继承的内存分布
- C++中继承的内存分布
- C++对象内存分布(3) - 菱形继承(virtual)
- C++虚拟继承__对象内存的分布_虚继承会多余分配虚表v-tab的指
- C++ 虚继承 虚函数 内存分布
- c/c++: c++继承 内存分布 虚表 虚指针 (转)
- C++继承多态下的内存分布
- C++继承、多重继承与虚基类 继承、多重继承时对象内存分布