. 基本概念
位元組對齊:電腦儲存系統
中以Byte為單位儲存資料
,不同資料類型所佔的空間
不同,如:整型(int)資料佔4個位元組,字
符型(char)資料佔一個位元組,短整型(short)資料佔兩個位元組,等等。電腦為了快速的讀寫資料,預設情況下將資料存放在某個地址的起始位置,
如:整型資料(int)預設儲存在地址能被4整除的起始位置,字元型資料(char)可以存放在任何地址位置(被1整除),短整型(short)資料存放區
在地址能被2整除的起始位置。這就是預設位元組對齊。
2. 舉例說明
很顯然預設對齊會浪費很多空間,例如如下結構:
struct student
{
char name[5];
int num;
short score;
}
本
來只用了11bytes(5+4+2)的空間,但是由於int型預設4位元組對齊,存放在地址能被4整除的起始位置,即:如果name[5]從0開始存放,
它佔5bytes,而num則從第8(位移量)個位元組開始存放。所以sizeof(student)=16。於是中間空出幾個位元組閑置著。但這樣便於計算
機快速讀寫資料,是一種以空間換取時間的方式。其資料對齊如:
|char|char|char|char|
|char|----|----|----|
|--------int--------|
|--short--|----|----|
如果我們將結構體中變數的順序改變為:
struct student
{
int num;
char name[5];
short score;
}
則,num從0開始存放,而name從第4(位移量)個位元組開始存放,連續5個位元組,score從第10(位移量)開始存放,故
sizeof(student)=12。其資料對齊如:
|--------int--------|
|char|char|char|char|
|char|----|--short--|
如果我們將結構體中變數的順序再次改為為:
struct student
{
int num;
short score;
char name[5];
}
則,sizeof(student)=12。其資料對齊如:
|--------int--------|
|--short--|char|char|
|char|char|char|----|
PS:sizeof只是計算分配在棧上的空間,比如在結構體上的static成員變數是不計算在其內空間的