什么是位段?
1、位段的成员必须是 int、unsigned int 或signed int(整型家族)
2、位段的成员名后边有一个冒号和一个数字
如:
struct A
{
int _a:2;
int _b:5;
int _c:10;
int _d:30;
};
A就是位段类型
位段内存分配
位段的空间上是按照需要以4个字节( int )或者1个字节( char )的方式来开辟的
接下来使用例子展开学习
int main()
{
unsigned char puc[4];
struct tagPIM
{
unsigned char ucPim1;
unsigned char ucData0 : 1;
unsigned char ucData1 : 2;
unsigned char ucData2 : 3;
}*pstPimData;
pstPimData = (struct tagPIM*)puc;
memset(puc,0,4);
pstPimData->ucPim1 = 2;
pstPimData->ucData0 = 3;
pstPimData->ucData1 = 4;
pstPimData->ucData2 = 5;
printf("%02x %02x %02x %02x\n",puc[0], puc[1], puc[2], puc[3]);
return 0;
}
分析上面打印的结果:
使用画图讲解:
该结构体大小需要2个字节,因为第一个char 用了八个比特位,刚好用了一个字节,第二个字节需要1个比特位就开辟了一个字节,剩下的7个比特位刚好用到第三和第四个上面。
然后将2、3、4和5分别转换成二进制的形式,有些放不下的只能取低位的数。因此有了右边这幅图,最后按照16进制输出,其中不够两位的前面补0,以上是全部分析。
结果:02 29 00 00
位段存在的问题
1. int 位段被当成有符号数还是无符号数是不确定的。
2. 位段中最大位的数目不能确定。(16位机器最大16,32位机器最大32,写成27,在16位机
器会出问题。
3. 位段中的成员在内存中从左向右分配,还是从右向左分配标准尚未定义。
4. 当一个结构包含两个位段,第二个位段成员比较大,无法容纳于第一个位段剩余的位时,是
舍弃剩余的位还是利用,这是不确定的。