C++中的內(nèi)存對齊實例詳解
C++中的內(nèi)存對齊實例詳解
內(nèi)存對齊
在我們的程序中,數(shù)據(jù)結(jié)構(gòu)還有變量等等都需要占有內(nèi)存,在很多系統(tǒng)中,它都要求內(nèi)存分配的時候要對齊,這樣做的好處就是可以提高訪問內(nèi)存的速度。
我們還是先來看一段簡單的程序:
程序一
 #include <iostream>
 using namespace std;
 
 struct X1
 {
  int i;//4個字節(jié)
  char c1;//1個字節(jié)
  char c2;//1個字節(jié)
 };
 
 struct X2
 {
  char c1;//1個字節(jié)
  int i;//4個字節(jié)
  char c2;//1個字節(jié)
 };
 
 struct X3
 {
  char c1;//1個字節(jié)
  char c2;//1個字節(jié)
  int i;//4個字節(jié)
 };
 int main()
 {  
   cout<<"long "<<sizeof(long)<<"\n";
   cout<<"float "<<sizeof(float)<<"\n";
   cout<<"int "<<sizeof(int)<<"\n";
   cout<<"char "<<sizeof(char)<<"\n";
 
   X1 x1;
   X2 x2;
   X3 x3;
   cout<<"x1 的大小 "<<sizeof(x1)<<"\n";
   cout<<"x2 的大小 "<<sizeof(x2)<<"\n";
   cout<<"x3 的大小 "<<sizeof(x3)<<"\n";
   return 0;
 }
這段程序的功能很簡單,就是定義了三個結(jié)構(gòu)X1,X2,X3,這三個結(jié)構(gòu)的主要區(qū)別就是內(nèi)存數(shù)據(jù)擺放的順序,其他都是一樣的,另外程序輸入了幾種基本類型所占用的字節(jié)數(shù),以及我們這里的三個結(jié)構(gòu)所占用的字節(jié)數(shù)。
這段程序的運行結(jié)果為:
long 4 float 4 int 4 char 1 x1 的大小 8 x2 的大小 12 x3 的大小 8
結(jié)果的前面四行沒有什么問題,但是我們在最后三行就可以看到三個結(jié)構(gòu)占用的空間大小不一樣,造成這個原因就是內(nèi)部數(shù)據(jù)的擺放順序,怎么會這樣呢?
下面就是我們需要講的內(nèi)存對齊了。
內(nèi)存是一個連續(xù)的塊,我們可以用下面的圖來表示, 它是以4個字節(jié)對一個對齊單位的:
     圖一
讓我們看看三個結(jié)構(gòu)在內(nèi)存中的布局:
首先是 X1,如下圖所示
X1 中第一個是 Int類型,它占有4字節(jié),所以前面4格就是滿了,然后第二個是char類型,這中類型只占一個字節(jié),所以它占有了第二個4字節(jié)組塊中的第一格,第三個也是char類型,所以它也占用一個字節(jié),它就排在了第二個組塊的第二格,因為它們加在一起大小也不超過一個塊,所以他們?nèi)齻€變量在內(nèi)存中的結(jié)構(gòu)就是這樣的,因為有內(nèi)存分塊對齊,所以最后出來的結(jié)果是8,而不是6,因為后面兩個格子其實也算是被用了。
再次看看X2,如圖所示
X2中第一個類型是Char類型,它占用一個字節(jié),所以它首先排在第一組塊的第一個格子里面,第二個是Int類型,它占用4個字節(jié),第一組塊已經(jīng)用掉一格,還剩3格,肯定是無法放下第二Int類型的,因為要考慮到對齊,所以不得不把它放到第二個組塊,第三個類型是Char類型,跟第一個類似。所因為有內(nèi)存分塊對齊,我們的內(nèi)存就不是8個格子了,而是12個了。
再看看X3,如下圖所示:
關(guān)于X3的說明其實跟X1是類似的,只不過它把兩個1個字節(jié)的放到了前面,相信看了前面兩種情況的說明這里也是很容易理解的。
唉,寫到這手都累了,關(guān)鍵是要畫圖,希望通過此文能讓你理解內(nèi)存對齊的基本概念,如果有問題,請留言。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持,如有疑問,請留言,共同進步!
您可能感興趣的文章
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用函數(shù)刪除字符
 - 04-02c語言沒有round函數(shù) round c語言
 - 01-10深入理解C++中常見的關(guān)鍵字含義
 - 01-10使用C++實現(xiàn)全排列算法的方法詳解
 - 01-10如何查看進程實際的內(nèi)存占用情況詳解
 - 01-10深入Main函數(shù)中的參數(shù)argc,argv的使用詳解
 - 01-10c++中inline的用法分析
 - 01-10如何尋找數(shù)組中的第二大數(shù)
 - 01-10用C++實現(xiàn)DBSCAN聚類算法
 - 01-10全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)
 


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
 - 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
 - 04-02c語言的正則匹配函數(shù) c語言正則表達
 - 04-02c語言用函數(shù)寫分段 用c語言表示分段
 - 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
 - 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
 - 04-02c語言沒有round函數(shù) round c語言
 - 04-02c語言分段函數(shù)怎么求 用c語言求分段
 - 04-02C語言中怎么打出三角函數(shù) c語言中怎
 - 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
 
隨機閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 08-05織夢dedecms什么時候用欄目交叉功能?
 - 01-11ajax實現(xiàn)頁面的局部加載
 - 01-10C#中split用法實例總結(jié)
 - 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 01-10delphi制作wav文件的方法
 - 08-05DEDE織夢data目錄下的sessions文件夾有什
 - 04-02jquery與jsp,用jquery
 - 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
 - 01-10使用C語言求解撲克牌的順子及n個骰子
 


