設置結構體的邊界對齊為1個字節,也就是所有數據在內存中是連續存儲的。
比如你在C語言中定義下面這樣的結構體:
struct s {
char ch;
int i;
};
然后在主函數中寫一句:printf("%d", sizeof(struct s))
也就是輸出結構體s所占的字節數
你覺得輸出結果會是多少呢?
我們知道,char型占用1個字節,int型占4個字節,那么輸出的結果是5嗎?
答案是否定的。你可以自己試一下,輸出結果為8。
為什么會這樣呢?這是因為編譯器為了讓程序跑得跟快,減少CPU讀取數據的指令周期,對結構體的存儲進行了優化。實際上第一個char型成員雖然本來只有1個字節,但實際上卻占用掉了4個字節,為的是讓第二個int型成員的地址能夠被4整除。因此實際占用的是8個字節。
而#pragma pack(1)讓編譯器將結構體數據強制連續排列,這樣的話,sizeof(struct s)輸出的結果就是5了。
設置內存對齊為:1字節對齊。使用方法如下:
#pragma pack(n)
struct s {
int i;
char ch;
};
#pragma pack()| /*取消指定對齊,恢復缺省對齊,等價於#pragma pack(pop)*/
意思就是 以下代碼編譯出來的是以1個字節的方式對齊的。這樣能節約內存資源,但是會在效率上有所影響
可是,雖說在效率上有一定的影響,不過,如果編寫的是基於協議,如串口通訊的程序,那么必須嚴格按照一定的規則進行接收數據包。那么,只要#pragma pack(1),讓數據在內存中是連續的,才好處理的。