為了避免混淆,做如下規定,以下**若不加特殊說明都執行於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(show)
該命令來檢視當前的對齊值,但是要注意的是,結果是以warning的形式輸出的,所以要在vs的警告視窗中才看得見,如下
warning c4810: value of pragma pack(show) == 8
projects-properties-configuration properties-c/c++-code generation-struct member alignment, 如果沒有修改過,則預設值是default,即8位元組對齊。
#pragma pack(num)
num是結構體的對齊值,比如下面的例子按四個位元組對齊。
#pragma pack(4)
projects-properties-configuration properties-c/c++-code generation
zz c c 巨集中 和 的用法
c c 巨集中 和 的用法 2007年05月14日 星期一 上午 10 19 一 一般用法 我們使用 把巨集引數變為乙個字串,用 把兩個巨集引數貼合在一起.用法 i nclude i nclude using namespace std define str s s define cons a,b ...
資料的對齊
linux沿用的對齊策略是2位元組資料型別 例如 short 的位址必須是2的倍數,而較大的資料型別 例如 int int float 和 double 的位址必須是4的倍數。注意,這個要求就意味著乙個short型別物件的位址的最低位必須等於0。類似地,任何 int 型別的物件或指標的位址的最低兩位...
c c 資料對齊
為了避免混淆,做如下規定,以下 若不加特殊說明都執行於32位平台,結構體的預設對齊值是8,各資料型別所佔位元組數分別為 char佔乙個位元組 int佔四個位元組 double佔八個位元組。請問下面的結構體大小是多少?struct test 複製 這個呢?struct test1 複製 在公布答案之前...