union和struct對齊大小問題

2021-07-26 05:56:08 字數 1343 閱讀 7108

對齊就是要滿足儲存變數的起始位址與對齊大小餘數為0。

對於union,分兩步:先算union對齊大小,對齊的大小是取決於union成員中位元組對齊最大的那個;再算union實際分配的空間,而分配給union的實際大小不僅要滿足是對齊大小的整數倍,同時要滿足實際大小不能小於最大成員的大小。

如:union u1

;成員a是char陣列,對齊大小為1位元組,成員b是int,對齊大小為4位元組,所以u1對齊大小為4位元組;分配給u1的實際大小既要是4位元組的整數倍,又要不小於最大成員a的大小,即位4的整數倍又要大於9,所以實際分配的空間為12位元組。

若其中的int b改為double,則對齊為8,大小為16。

複雜一點的情況:

union u2

;對齊是double的大小,為8,大小應當為是16。

對於stuct,分三步:先算struct的對齊大小,對齊的大小也是取決於struct成員中位元組對齊最大的那個;然後根據每個成員的對齊大小對齊每個成員算出分配的空間;最後算出struct實際分配的空間,在滿足對齊每個成員的基礎上,滿足是struct

對齊大小的整數倍。

struct s1

;對齊大小為8,對齊每個成員後大小為24,正好是8的整數倍,所以實際分配的大小就為24。

struct s2

;s1對齊大小為8,u1對齊大小為4,因此s2的對齊大小8,體積大小為大於24+12且要為8的倍數,結果為40。

這裡所說的union和struct的對齊,是指其作為其他複雜物件中的元素的時候要求的對齊,對於本身大小的計算並沒有關係。本身的大小只和其所包含的基本元素的對齊有關係。

struct的大小和內部元素的排列是有很大關係的,而union裡元素排序沒關係,因此在使用struct的時候,安排好元素的位置,可以減少結構體的大小

如:struct s3

;根據之前的原則,因為c需要4位元組對齊,因此b之後會有3位元組空餘。所以1+3(空餘)+4+13=21,要求為4的倍數,則為24。

若更改為

struct s4

則c之前會空餘2位元組,所以1+13+2+4=20,並且已經為4的倍數,所以大小就是20。

關於#pragma pack(),該標示用於重新指定對齊的大小,當元素的對齊大於指定的對齊大小的時候,成員和整個物件的對齊大小會採用相對較小的。

如:union u3

;該union的對齊為8,大小為16(大於9且為8的倍數)。

若加上#pragma pack(4)// pack(0)會採用預設的位元組(4)

則對於u3中的基本元素b,其對齊由原來的8變為4,而a的對齊仍然是1,則u3的對齊為4,大小為12。

當然u3的對齊也由8變成了4。

關於Union和Struct對齊

關於union,struct,還有機器數賦值,總是感覺自己認識不是特別深刻,這裡使用小demo程式加以說明,具體的詳細細節描述其它地方已經有說明和記錄,這裡不再說明。include union myun u int k a int main output size is 12 0 5 6 說明 in...

struct與union位元組對齊問題

c 語言的一大優勢就是對記憶體空間的控制,當然,在物件導向語言的壓力下,程式設計師更喜歡輕鬆的語言,不喜歡自己還要顧慮記憶體空間。可是,c 語言仍然有很強的生命力,尤其是在作業系統 嵌入式系統這兩方面,因為要直接操作硬體,c語言就顯現出自己強大的體制 機制 邏輯優勢。c語言對記憶體控制,有乙個始終困...

struct和union的大小

結構體預設對齊方式 在預設對齊方式下,結構體成員的記憶體分配滿足下面三個條件 1.第乙個成員的位址和結構體的首位址相同,即偏移量為0。2.結構體每個成員位址相對於結構體首位址的偏移量 offset 是該成員大小的整數倍,如果不是則編譯器會在成員之間新增填充位元組 internal adding 3....