zz C C 資料對齊

2021-09-30 09:55:29 字數 1752 閱讀 3095

為了避免混淆,做如下規定,以下**若不加特殊說明都執行於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 複製 在公布答案之前...