設置結構體的邊界對齊為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()|
意思就是 以下代碼編譯出來的是以1個字節的方式對齊的。這樣能節約內存資源,但是會在效率上有所影響
可是,雖說在效率上有一定的影響,不過,如果編寫的是基於協議,如串口通訊的程序,那么必須嚴格按照一定的規則進行接收數據包。那么,只要#pragma pack(1),讓數據在內存中是連續的,才好處理的。