關於C編譯器裡位元組對齊的問題

2021-03-31 21:13:57 字數 915 閱讀 4355

宣告:只是為了方便個人學習用:)

首先是來自http://blog.csdn.***/wenddy112/articles/300583.aspx《通過#pragma pack(n)改變c編譯器的位元組對齊方式》上的乙個問題:

對於下面的結構體

struct test

;結構各成員空間分配情況是怎樣的?

文章中解釋:

結構的第乙個成員x1,其偏移位址為0,佔據了第1個位元組。第二個成員x2為short型別,其起始位址必須2位元組對界,因此,編譯器在x2和x1之間填充了乙個空位元組。結構的第三個成員x3和第四個成員x4恰好落在其自然對界位址上,在它們前面不需要額外的填充位元組。在 test結構中,成員x3要求4位元組對界,是該結構所有成員中要求的最大對界單元,因而test結構的自然對界條件為4位元組,編譯器在成員x4後面填充了 3個空位元組。整個結構所佔據空間為12位元組。

同時,說明了更改c編譯器的預設位元組對齊方式: 在預設情況下,c編譯器為每乙個變數或是資料單元按其自然對界條件分配空間。一般地,可以通過下面的方法來改變預設的對界條件:

· 使用偽指令#pragma pack (n),c編譯器將按照n個位元組對齊。

· 使用偽指令#pragma pack (),取消自定義位元組對齊方式。

另外,還有如下的一種方式:

· __attribute((aligned (n))),讓所作用的結構成員對齊在n位元組自然邊界上。如果結構中有成員的長度大於n,則按照最大成員的長度來對齊。

· __attribute__ ((packed)),取消結構在編譯過程中的優化對齊,按照實際占用位元組數進行對齊。

以上的n = 1, 2, 4, 8, 16... 第一種方式較為常見。

下面是csdn上提出的問題(原文<>:http://blog.csdn.***/freefalcon/archive/2004/07/28/54839.aspx

編譯器與位元組對齊

編譯器版本 gcc 4.1.2 vc 6.0 上次研究了結構體和位元組對齊的問題,不過有個復合結構體有點奇怪。pragma pack 8 struct s1 struct s2 pragma pack 在gcc下,sizeof struct s2 20,但在vc 6.0下卻是24 其實,這個牽扯到了...

GCC編譯器的位元組對齊

include 由於在x86 32位機器 平台下,gcc編譯器預設按4位元組對齊,如 結構體4位元組對齊,即結構體成員變數所在的記憶體位址是4的整數倍 可以通過使用gcc中的 attribute 選項來設定指定的對齊大小。1 attribute packed 讓所作用的結構體取消在編譯過程中的優化對...

C 預編譯中關於位元組對齊的問題

通過 pragma pack n 改變c編譯器的位元組對齊方式 在c語言中,結構是一種復合資料型別,其構成元素既可以是基本資料型別 如int long float等 的變數,也可以是一些復合資料型別 如陣列 結構 聯合等 的資料單元。在結構中,編譯器為結構的每個成員按其自然對界 alignment ...