我的4个字节在哪里?

时间:2013-04-10 21:06:29

标签: c++

#include <iostream>
#include <cstdlib>

using std::cout;

class A
{

public :
    A() { cout << "A()" << this << "\n";}
    ~A() { cout << "~A()" << this << "\n";}
    //void func()  { }
    virtual void debug(int a)  { cout << "A::debug";}
private :
    int a;
};

class A1 : public A
{
public :
    A1() { cout << "A1()"<< this << "\n";}
    ~A1() { cout << "~A1()"<< this << "\n";}
private :
    int a1;
};
class A2 : public A
{
public :
    A2() { cout << "A2()"<< this << "\n";}
    ~A2() { cout << "~A2()"<< this << "\n";}
private :
    int a2;
};

class B : public A1, public A2
{
public :
    B() { cout << "B()"<< this << "\n";}
    ~B() { cout << "~B()"<< this << "\n";}
    void debug() { cout << "B::debug()";  }
private :
    int a3;
};
int main()
{
    cout << "sizeof(int)" << sizeof(int) << "\n";
    cout << "sizeof(void*)" << sizeof(void*) << "\n";
    cout << "sizeof(A): " << sizeof(A) << "\n";
    cout << "sizeof(A1): " << sizeof(A1) << "\n";
    cout << "sizeof(A2): " << sizeof(A2) << "\n";
    cout << "sizeof(B): " << sizeof(B) << "\n";
    B b;
    b.debug();

}

输出:

sizeof(int)4
sizeof(void*)4
sizeof(A): 8
sizeof(A1): 12
sizeof(A2): 12
**sizeof(B): 28**
A()0x28fef4
A1()0x28fef4
**A()0x28ff00**
A2()0x28ff00
B()0x28fef4
B::debug()~B()0x28fef4
~A2()0x28ff00
~A()0x28ff00
~A1()0x28fef4
~A()0x28fef4

A1和A2都是4(vtbl)+ 4(A&#39; sint)+ 4(各个int)= 12个字节,但B是28个字节 我知道它不能保证,但可能使用这4个字节...我没有看到任何填充问题?任何人都可以指出我错过了什么吗?

3 个答案:

答案 0 :(得分:7)

  

sizeof(A): 8

类型A的成员类型为int,在您的平台中为4个字节。它还有一个虚函数,这意味着为类的每个对象分配vptr(虚拟表指针),它的大小是另外4个字节。

  

**sizeof(B): 28**

B包含一个类型为A1的对象(12个字节),以及一个类型为A2的对象(另外12个字节),并为总共添加另一个int 12+12+4 = 28个字节。这很简单。

答案 1 :(得分:2)

结构内数据项的机器字大小对齐。

有关详细信息,请参阅结构包装。

答案 2 :(得分:1)

多重继承将产生可能不同大小的特定于实现的内存布局。 Virtual tables and virtual pointers for multiple virtual inheritance and type casting