不同编译器下虚继承层次的对象的内存布局 8, 20, 32

来源:互联网 发布:java sql commit没反应 编辑:程序博客网 时间:2024/05/16 17:14
#include<iostream>using namespace std;class A{    char k[3];public:    virtual void aa() {};};class B:virtual public  A{    char j[3];public:    virtual void bb() {};};class C:virtual public  B{    char i[3];public:    virtual void cc() {};};int main(){    cout<<"sizeof(A): "<<sizeof(A)<<endl;    cout<<"sizeof(B): "<<sizeof(B)<<endl;    cout<<"sizeof(C): "<<sizeof(C)<<endl;    return 0;}

VC2008输出为:

8

20

32

解释为:

sizeof(A) = sizeof(char A.i[3]) + sizeof(A.vptr) = 4 + 4 = 8;

sizeof(B) = sizeof(char B.i[3]) + sizeof(A) + sizeof(B.vptr) + sizeof(virtual base pointer虚继承造成) = 4 + 8 + 4 + 4 = 20;

注:GCC实现比较简单,不管是否虚继承,GCC都是将虚表指针在整个继承关系中共享的,不共享的是指向虚基类的指针。

A,B分别自己维护一个虚表指针,它指向自己的虚函数

sizeof(C) = sizeof(char C.i[3]) + sizeof(A)  + sizeof(B) + sizeof(C.vptr)- sizeof(virtual base pointer使得C类中只有一个虚基类指针) = 4  + 8 +  20 + 4 - 4 = 32


GCC 4.6.2输出为:

8

16

24

解释为:

sizeof(A) = sizeof(char A.i[3]) + sizeof(vptr) = 4 + 4 = 8;

sizeof(B) = sizeof(char B.i[3]) + sizeof(A) + sizeof(virtual base pointer虚继承造成) = 4 + 8 + 4 = 16;

sizeof(C) = sizeof(char C.i[3]) + sizeof(A)  + sizeof(B) - sizeof(virtual base pointer使得C类中只有一个虚基类指针 = 4  + 8 +  16 - 4 =  24;