結構體對齊

2021-06-29 13:52:04 字數 1173 閱讀 2700

為了避免混淆,做如下規定,以下**若不加特殊說明都執行於32位平台,結構體的預設對齊值是8,各資料型別所佔位元組數分別為

char佔乙個位元組

int佔四個位元組

double佔八個位元組。

請問下面的結構體大小是多少?

struct

test

;

這個呢?

struct

test1

;

在公布答案之前先看一下對齊的規則。

一般來說,結構體的對齊規則是先按資料型別自身進行對齊,然後再按整個結構體進行對齊,對齊值必須是2的冪,比如1,2, 4, 8, 16。如果乙個型別按n位元組對齊,那麼該型別的變數起始位址必須是n的倍數。比如int按四位元組對齊,那麼int型別的變數起始位址一定是4的倍數,比如0x0012ff60,0x0012ff48等。

資料自身的對齊值通常就是資料型別所佔的空間大小,比如int型別佔四個位元組,那麼它的對齊值就是4

整個結構體的對齊值一般是結構體中最大資料型別所佔的空間,比如下面這個結構體的對齊值就是8,因為double型別佔8個位元組。

struct

test2

;

有了上面的基礎,再回過頭去看看一開始的兩個例子

先看結構體test

1 c是char型別,按1個位元組對齊

2 i是int型別,按四個位元組對齊,所以在c和i之間實際上空了三個位元組。

整個結構體一共是1 + 3(補齊)+ 4 = 8位元組。

再看test1

i是int型別,按4位元組對齊

d是double型別,按8位元組對齊,所以i和d之間空了4位元組

c是char型別,按1位元組對齊。

所以整個結構體是 4(i) + 4(補齊)+ 8(d) + 1(c) =  17位元組,注意!還沒完,整個結構體還沒有對齊,因為結構體中空間最大的型別是double,所以整個結構體按8位元組對齊,那麼最終結果就是17 + 7(補齊) = 24位元組。

我們對test1做一點改動

struct

test1

;

這時test1的大小就變成了16,而不是24了,節省了8個位元組!可見結構體中成員的書寫順序對結構體大小的影響還是很大的,乙個好的建議是,按照資料型別由小到大的順序進行書寫。

結構體對齊

現在去掉第乙個成員變數為如下 pragma pack 4 class testc int nsize sizeof testc 按照正常的填充方式nsize的結果應該是8,為什麼結果顯示nsize為6呢?事實上,很多人對 pragma pack的理解是錯誤的。pragma pack規定的對齊長度,實...

結構體對齊

結構體對齊問題 以下結論均在gnu gcc上驗證 概念 偏移量 成員位址相對結構體位址的偏移 對齊原則 1.結構體中某成員的偏移量必須是該成員型別大小的整數倍 b 的偏移量必須是 short 大小的整數倍,故在 a 後面填充乙個位元組 c 的 型別大小是double,在ansi c中,c 的偏移量是...

結構體對齊

結構體對齊方式 1.pragma pack x 32系統預設值4,結構體元素最大長度,取三者最小值,作為每個元素對齊計算的值的倍數,並且總和是最小值的倍數!假的 於2015 12 26 修改 1.資料成員對齊原則 結構或聯合的資料成員,第乙個資料成員放在offset為0的地方,以後每個成員按照 pr...