位域

1. 什么叫位域

  有些信息在存储时,并不需要占用一个完整的字节,而只需占一个或几个二进制位。例如,在存放一个开关量时,只有0和1 两种状态,用一个二进制位表示即可。而在使用C语言开发程序,特别是一些系统级或嵌入式程序时,内存往往是特别宝贵的。为了节省存储空间,并使处理简便,C语言提供了一种数据结构,称为“位域”或“位段”。

  所谓“位域”是把一个字节中的二进制位划分为几个不同的区域,并说明每个区域的位数。每个区域有一个域名,允许在程序中按域名进行操作。这样一个字节的二进制位就可以表示几个不同的量。

2. 位域及位域变量的定义

  位域的定义与结构定义相仿,其形式为:
 
   struct 位域结构名

   {

       类型说明符 位域名1:位域长度1;

        ……

       类型说明符 位域名n:位域长度n;

    };
   同样的,位域变量的定义与结构体变量定义的方式相同。可采用先定义位域后定义位域变量,同时定义或者直接定义位域变量三种方式。具体的形式此处就不再叙述。

例如,下面采用同时定义的方式定义一个位域变量field:

    struct byte_struct

    {

        int x:8;
 
        int y:2;

        int z:6;

     } field;

其表明field为byte_struct类型变量,共占2个字节。其中位域x占8位,位域y占2位,位域z占6位。

例如,下面的定义是非法的:

    struct bs

    {

        unsigned a:2;

        unsigned b:10;  //位域长度不能大于8位

     };

   位域可以无位域名,这时其只用来做填充或调整位置,而不能使用。例如:

   struct bs

  {

      unsigned a:4;

      unsigned:4;     //此4位不能使用

   };

4. 位域的使用
  
   位域从本质上说就是一种结构类型,不过其成员是按二进位分配的。所以位域的使用和结构成员的使用相同。

   下面的程序清单演示了普通位域变量和指针位域变量的使用。

   #include <stdio.h>

   //位域声明

   struct byte_struct

   {

       unsigned a:4;

       unsigned b:2;  

       unsigned c:1;

    };

   void main()

   {

       struct byte_struct bit; //定义普通位域变量

       //普通位域变量的使用

       bit.a=1;

       bit.b=7;

       bit.c=15;

       printf("%d,%d,%d/n",bit.a,bit.b,bit.c);

       struct byte_struct *pbit; //定义指针位域变量

       //指针位域变量的使用

       pbit=&bit;

       pbit->a=0;

       pbit->b&=3;

       pbit->c|=1;

       printf("%d,%d,%d/n",pbit->a,pbit->b,pbit->c);

   }

可以看出,位域变量的使用和结构体变量从形式上完全相同,只不过成员都是用二进制位来表示,所以会经常使用一些位操作。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值