http://blog.csdn.net/zyyoung/article/details/6166939
- #include<iostream.h>
- class a {};
- class b{};
- class c:public a{
- virtual void fun()=0;
- };
- class d:public b,public c{};
- int main(){
- cout<<"sizeof(a)"<<sizeof(a)<<endl;
- cout<<"sizeof(b)"<<sizeof(b)<<endl;
- cout<<"sizeof(c)"<<sizeof(c)<<endl;
- cout<<"sizeof(d)"<<sizeof(d)<<endl;
- return 0;
- }
- 本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/lenic/archive/2009/05/18/4199114.aspx
程序執行的輸出結果爲:
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