sizeof 類 的大小

2021-08-07 13:04:29 字數 1513 閱讀 2564

什麼是類的例項化,所謂類的例項化就是在記憶體中分配一塊位址.

那我們先看看乙個例子:

#include

class a {};

class b{};

class c:public a;

class d:public b,public c{};

int main()

程式執行的輸出結果為:

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。之前錯以為空類為乙個位元組,增加乙個指標後,該類大小為5……

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

記憶體對齊的原則,所以類d的大小為8個位元組。

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

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

下面我們再看乙個例子.

#include

class a;

class b;

int b::data1=0;

void mian()

void f(int x);

class b;

int b::xs=0;

void main(){

a s(10);

s.f(10);

cout

<<"sozeof(a)"

<<<"sizeof(b)"

<10

sizeof

(a) 8

sizeof

(b) 8

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

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

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

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

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

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

本文**:

sizeof 類的大小

首先,類的大小是什麼?確切的說,類只是乙個型別定義,它是沒有大小可言的。用sizeof運算子對乙個型別名操作,得到的是具有該型別實體的大小。如果 class a a obj 那麼sizeof a sizeof obj 那麼sizeof a 的大小和成員的大小總和是什麼關係呢,很簡單,乙個物件的大小大...

sizeof 類大小,空類大小

乙個類的例項化物件所佔空間的大小?注意不要說類的大小,是類的物件的大小.首先,類的大小是什麼?確切的說,類只是乙個型別定義,它是沒有大小可言的。用sizeof運算子對乙個型別名操作,得到的是具有該型別實體的大小。如果 class a a obj 那麼sizeof a sizeof obj 那麼siz...

sizeof 類大小,空類大小

乙個類的例項化物件所佔空間的大小?注意不要說類的大小,是類的物件的大小.首先,類的大小是什麼?確切的說,類只是乙個型別定義,它是沒有大小可言的。用sizeof運算子對乙個型別名操作,得到的是具有該型別實體的大小。如果 class a a obj 那麼sizeof a sizeof obj 那麼siz...