C:位段的使用

目录

一、位段:

二、位段的跨平台问题

三、例题:

四、分析:


一、位段:

        位段的存在与结构体对齐的原因恰恰相反。结构体对齐是牺牲空间换速度,位段是牺牲速度换空间。冒号后的数字是定义的n个bit位。位段的成员必须是:int、unsigned int 、signed int、char、unsigned char 、signed char.在分配空间的时候,会默认给四个字节或一个字节,根据成员类型。

二、位段的跨平台问题:

        1、int 位段被当作有符号数还是无符号数是不确定的。

        2、位段中最大的数目不能确定。(16位机器最大16,32位机器最大32,例如定义为27,在16位的机器上会出现问题。

        3、位段中的成员在内存中从左向右分配还是从右向左分配尚未定义。

        4、当一个结构体包含两个位段,第二个位段比较大,无法容纳于第一个位段剩余的位时,是舍弃还是利用,这是不知道的。

三、例题:

struct _Record_Struct
{
  unsigned char Env_Alarm_ID : 4;
  unsigned char Para1 : 2;
  unsigned char state;
  unsigned char avail : 1;
}*Env_Alarm_Record;

 四、分析:

        题目中Env_Alarm_ID定义占4bit大小,Para1占2bit大小,state默认占1byte大小,avail占1bit大小。因为总左向右还是从右向左分配时未知的,此次分析就假设从右向左,所以分配情况如下图。

        

 而avail排在默认的atate后面,所以就会新开辟一个空间,avail在新的空间里面占1bit,所以整个结构体的大小就是3byte。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菲利普赵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值