C 類的大小的計算

2021-05-08 05:17:37 字數 1321 閱讀 6839

c++的類的大小現在經常出現在筆試題目當中。

那我們先看看乙個例子:

程式的輸出結果:

sizeof(a) =1

sizeof(b)=1

sizeof(c)=4

sizeof(d)=8

為什麼會出現這種結果呢?初學者肯定會很煩惱是嗎?類a,b明明是空類,它的大小應該為為0,為什麼 編譯器輸出的結果為1呢?這就是我們剛才所說的例項化的原因(空類同樣可以被例項化),每個例項在記憶體中都有乙個獨一無二的位址,為了達到這個目的,編譯器往往會給乙個空類隱含的加乙個位元組,這樣空類在例項化後在記憶體得到了獨一無二的位址.所以a,b的大小為1.

而類c是由類a派生而來,它裡面有乙個純虛函式,由於有虛函式的原因,有乙個指向虛函式的指標(vptr),在32位的系統分配給指標的大小為4個位元組,所以最後得到c類的大小為4.

類d的大小更讓初學者疑惑吧,類d是由類b,c派生邇來的,它的大小應該為二者之和5,為什麼卻是8  呢?這是因為為了提高例項在記憶體中的訪問效率.類的大小往往被調整到系統的整數倍.並採取就近的法則,裡哪個最近的倍數,就是該類的大小,所以類d的大小為8個位元組.

當然在不同的編譯器上得到的結果可能不同,但是這個實驗告訴我們初學者,不管類是否為空類,均可被例項化(空類也可被例項化),每個被例項都有乙個獨一無二的位址.

我所用的編譯器為vc++ 6.0.

下面我們再看乙個例子.

執行結果為:

sizeof(a)=4;

sizeof(b)=4;

為什麼類b多了乙個資料成員,卻大小和類a的大小相同呢?因為:類b的靜態資料成員被編譯器放在程式的乙個global  data members中,它是類的乙個資料成員.但是它不影響類的大小,不管這個類實際產生了多少例項,還是派生了多少新的類,靜態成員資料在類中永遠只有乙個實體存在,而類的非靜態資料成員只有被例項化的時候,他們才存在.但是類的靜態資料成員一旦被宣告,無論類是否被例項化,它都已存在.可以這麼說,類的靜態資料成員是一種特殊的全域性變數.

所以a,b的大小相同.

下面我們看乙個有建構函式,和析構函式的類的大小,它又是多大呢?

程式執行輸出結果為:

10 ,

sizeof(a) 8

sizeof(b) 8

它們的結果均相同,可以看出類的大小與它當中的建構函式,析構函式,以及其他的成員函式無關,只與它當中的成員資料有關.

從以上的幾個例子不難發現類的大小:

1.為類的非靜態成員資料的型別大小之和.

2.有編譯器額外加入的成員變數的大小,用來支援語言的某些特性(如:指向虛函式的指標).

3.為了優化訪問效率,進行的邊緣調整.

4 與類中的建構函式,析構函式以及其他的成員函式無關.

C 類大小的計算

這裡記錄一下怎麼計算類物件的大小。大概總結下,類的大小需要考慮以下內容 非靜態成員變數大小 資料對齊到多少位 有無虛函式 即需不需要指向虛函式表的指標,如果考慮繼承的情況,則還需要看繼承了多少個指向虛函式表的指標 首先我們看什麼都沒有的時候的例子 可以看到,類例項化的物件的大小為1。這是因為即使類是...

C 類的大小計算

1.空類的大小 class c2 結果 sizeof c2 1 分析 這是因為當我們例項化乙個類物件時,就是為其分配記憶體空間,並且每乙個例項化的類都會有乙個獨一無二的記憶體位址,空類也不例外,必須為其分配乙個記憶體,因此編譯器給分配了乙個位元組的記憶體,使其獨一無二。2.只含有乙個虛函式的類的大小...

C 類大小的計算(對齊,繼承)

先看這麼個問題 已知 class cbase 那麼執行cout sizeof cbase 為什麼空的什麼都沒有是1呢?類的例項化,所謂類的例項化就是在記憶體中分配一塊位址,每個例項在 記憶體中都有獨一無二的位址。同樣空類也會被例項化,所以編譯器會給空類隱含的新增乙個位元組,這樣空類例項化之後就有了 ...