#pragma pack(push,1)與#pragma pack(1)的區別
睿豐德科技 專注RFID識別技術和條碼識別技術與管理軟件的集成項目。質量追溯系統、MES系統、金蝶與條碼系統對接、用友與條碼系統對接
這是給編譯器用的參數設置,有關結構體字節對齊方式設置, #pragma pack是指定數據在內存中的對齊方式。
#pragma pack (n) 作用:C編譯器將按照n個字節對齊。
#pragma pack () 作用:取消自定義字節對齊方式。
#pragma pack (push,1) 作用:是指把原來對齊方式設置壓棧,并設新的對齊方式設置為一個字節對齊
#pragma pack(pop) 作用:恢復對齊狀態
因此可見,加入push和pop可以使對齊恢復到原來狀態,而不是編譯器默認,可以說后者更優,但是很多時候兩者差別不大
如:
#pragma pack(push) //保存對齊狀態
#pragma pack(4)//設定為4字節對齊
相當于 #pragma pack (push,4)
#pragma pack (1) 作用:調整結構體的邊界對齊,讓其以一個字節對齊;<使結構體按1字節方式對齊>
#pragma pack ()
例如:
#pragma pack(1)
struct sample
{
char a;
double b;
};
#pragma pack()
注:若不用#pragma pack(1)和#pragma pack()括起來,則sample按編譯器默認方式對齊(成員中size最大的那個)。即按8字節(double)對齊,則sizeof(sample)==16.成員char a占了8個字節(其中7個是空字節);若用#pragma pack(1),則sample按1字節方式對齊sizeof(sample)==9.(無空字節),比較節省空間啦,有些場和還可使結構體更易于控制。
RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成