c++類大小問題


1.空類

class A
{
};

sizeof(A); //1

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

2.虛函數類

class A
{
    virtual void Fun();
};

sizeof(A); //4

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

3.普通數據成員

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

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

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字節)。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM