您好,登錄后才能下訂單哦!
這篇“C++中類的大小實例分析”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“C++中類的大小實例分析”文章吧。
#include<iostream> using namespace std; class MyClass { public: MyClass(){ int i = 0; float f = 0.01f; }; int getI(){ return i; } int getF(){ return f; } private: int i; float f; //靜態變量實際上是其全局變量,它存儲在全局/靜態存儲區,不占對象空間 static int staNum; }; int MyClass::staNum = 2; int main() { MyClass myclass; cout << "myclass的大小" << sizeof(myclass) << endl; return 0; }
我們可以看到,在創建類的對象中,真正占據棧空間的只有兩個成員變量,分別為4個字節。靜態成員變量實際上與全局變量一起存儲在全局存儲區,而成員函數則與其他函數一樣存在于代碼區。
#include<iostream> using namespace std; class MyClass { public: MyClass(){}; private: }; int main() { MyClass myclass; cout << "myclass的大小" << sizeof(myclass) << endl; return 0; }
在使用類的指針的時候,如果類的的大小為0,那么排在一起的幾個空類地址都是一樣的話,我們又怎么知道是哪個呢?
#include<iostream> using namespace std; struct MyStruct1 { bool b1; bool b2; int i1; }; struct MyStruct2 { bool b1; int i1; bool b2; }; struct MyStruct3 { bool b1; short s1; }; int main() { MyStruct1 s1; MyStruct2 s2; MyStruct3 s3; cout << "MyStruct1的大小" << sizeof(s1) << endl; cout << "MyStruct2的大小" << sizeof(s2) << endl; cout << "MyStruct3的大小" << sizeof(s3) << endl; return 0; }
當我們按照不同的的順序排列變量的時候會發現,類的大小是不盡相同的。第一種情況,MyStruct中的兩個布爾連在一起,如果后面沒有變量,編譯器會自動填充2個字節;而現在后面還有一個整形i,整形跨越了兩個4字節,在讀取整形的時候需要兩個4字節,因此編譯器會在這種情況下也會在i1填充2個字節,從而是i1在下一個字節開始。對于第二種情況,MyStruct2中由于兩個布爾類型被整形隔開,我們需要兩次填充。第三種情況,MyStruct3中由于short只有兩個字節,因此只需要填充一個字節。
以上就是關于“C++中類的大小實例分析”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。