位的對齊順序
位域的使用,位域一般存放數據默認都是字節內低位對齊,就是前面的是低位,後面的是高位;
如下面的代碼一樣;
typedef struct bitmap
{
char bit0:1
char bit1:1
char bit2:1
char bit3:1
char bit4:1
char bit5:1
char bit6:1
char bit7:1
};
位域、結構體(struct)和聯合體(union),需要小心這個位的高低位
也存在是從高位開始的,所以要先測試下
測試代碼
#include <stdio.h>
typedef struct{
unsigned char bit0 : 1;
unsigned char bit1 : 1;
unsigned char bit2 : 1;
unsigned char bit3 : 1;
unsigned char bit4 : 1;
unsigned char bit5 : 1;
unsigned char bit6 : 1;
unsigned char bit7 : 1;
} sByte;
typedef union{
unsigned char byte;
sByte bit;
}uByte8;
int main(void)
{
uByte8 p;
p.byte = 0x01;//b 0000 0001
if (p.bit.bit0 == 1)
printf("第一個位爲1,低位對齊\n");
else
printf("第一個位爲0,高位對齊\n");
return 0;
}