c++類大小問題

1.空類函數

class A
{
};

sizeof(A); //1

解析:類的實例化就是爲每一個實例在內存中分配一塊地址;每一個類在內存中都有惟一的標識,所以空類被實例化時,編譯器會隱含地爲其添加一個字節,以做區分。spa

2.虛函數類指針

class A
{
    virtual void Fun();
};

sizeof(A); //4

解析:當一個類中包含虛函數時,會有一個指向其虛函數表的指針vptr,系統爲類指針分配大小爲4個字節(即便有多個虛函數)。code

3.普通數據成員blog

class A
{
    int a;
    char b;
};

sizeof(A); //8

解析:普通數據成員,按照其數據類型分配大小,因爲字節對齊,因此a+b=8字節。繼承

4.靜態數據成員內存

class A
{
    int a;
    static int b;
};

sizeof(A); //4

解析:靜態數據成員存放的是全局數據段,即便它是類的一個成員,但不影響類的大小;無論類產生多少實例或者派生多少子類,靜態成員數據在類中永遠只有一個實體存在。而類的非靜態數據成員只有被實例化時,才存在,但類的靜態數據成員一旦被聲明,不管類是否被實例化,它都已存在,類的靜態數據成員能夠說是一種特殊的全局變量。編譯器

5.普通成員函數編譯

class A
{
    void Fun();
};

sizeof(A); //1

解析:類的大小與它的構造函數、析構函數以及其餘成員函數無關,只與它的數據成員相關。class

6.普通繼承

class A
{
    int a;
};

class B:public A
{
    int b;
};

sizeof(B); //8

解析:普通類的繼承,類的大小爲自己數據成員大小+基類數據成員大小。

7.虛函數繼承

virtual class A
{
    int a;
};

class B:virtual public A
{
    int b;
};

sizeof(B); //12

解析:虛函數類的繼承,派生類大小=派生類自身成員大小+基類數據成員大小+虛擬指針大小(即便繼承多個虛基類,也只有一個指向其虛函數表的指針vptr,大小爲4字節)。

相關文章
相關標籤/搜索