C語言 記憶體對齊

2021-05-25 07:56:59 字數 1225 閱讀 3213

寫出乙個struct,然後sizeof,你會不會經常對結果感到奇怪?sizeof的結果往往都比你宣告的變數總長度要大,這是怎麼回事呢?講講位元組對齊吧.

/******************************分割線

如果體系結構是不對齊的,a中的成員將會乙個挨乙個儲存,從而sizeof(a)為11。顯然對齊更浪費了空間。那麼為什麼要使用對齊呢?

體 繫結構的對齊和不對齊,是在時間和空間上的乙個權衡。對齊節省了時間。假設乙個體繫結構的字長為w,那麼它同時就假設了在這種體系結構上對寬度為w的資料 的處理最頻繁也是最重要的。它的設計也是從優先提高對w位資料操作的效率來考慮的。比如說讀寫時.............此處省略50萬字

上面是你隨便 google一下,人家就可以跟你解釋的,一大堆的道理,我們沒怎麼多時間,討論為何要對齊.直入主題,怎麼判斷記憶體對齊規則,sizeof的結果怎麼來的,請牢記以下3條原則:(在沒有#pragma pack巨集的情況下)

1:資料成員對齊規則:結構(struct)(或聯合(union))的資料成員,第乙個資料成員放在offset為0的地方,以後每個資料成員儲存的起始位置要從該成員大小的整數倍開始(比如int在32位機為4位元組,則要從4的整數倍位址開始儲存。

2:結構體作為成員:如果乙個結構裡有某些結構體成員,則結構體成員要從其內部最大元素大小的整數倍位址開始儲存.(struct a裡存有struct b,b裡有char,int ,double等元素,那b應該從8的整數倍開始儲存.)

3:收尾工作:結構體的總大小,也就是sizeof的結果,.必須是其內部最大成員的整數倍.不足的要補齊.

等你看完此3條原則,2分鐘已經過去,抓緊時間,實戰3分鐘:

typedef struct bb

bb;typedef struct aa

aa;int main()

{aa a;

cout《結果是

48 24

ok,上面的全看明白了,記憶體對齊基本過關.

再講講#pragma pack().

在**前加一句#pragma pack(1),你會很高興的發現,上面的**輸出為

32 16

bb是4+8+4=16,aa是2+4+8+2+16=32;

這不是理想中的沒有記憶體對齊的世界嗎.沒錯,#pragma pack(1),告訴編譯器,所有的對齊都按照1的整數倍對齊,換句話說就是沒有對齊規則.

明白了不?

那#pragma pack(2)的結果又是多少呢?對不起,5分鐘到了,自己去測試吧.

c語言記憶體對齊

記錄平常所學,以便回顧。c語言中存在著記憶體對齊問題,在struct儲存中尤為明顯,這裡先介紹一種情況,以後接著補充。typedef unsigned char u8 typedef unsigned short u16 typedef unsigned long u32 typedef unsig...

C語言記憶體對齊

一.記憶體對齊的初步講解 記憶體對齊可以用一句話來概括 資料項只能儲存在位址是資料項大小的整數倍的記憶體位置上 例如int型別占用4個位元組,位址只能在0,4,8等位置上。include struct xx int main 執行結果如下 a ffbff5ec b ffbff5e8 c ffbff5...

C語言 記憶體對齊

記憶體對齊 結構體內成員按自身長度自對齊,即按他們的起點長度必須是自身長度的整數倍對齊 如在32位系統下,int 型的開始位址必須位0,4,8,這種整形資料型別長度大小的倍數開始 結構體的總大小必須位有效對齊值的整數倍 有效對齊值的確定 當有效對齊值為明確指定時,以結構體內成員的最長者的長度為有效對...