• C结构体之位域(位段)


    有些信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位。例如在存放一个开关量时,只有0和1 两种状态, 用一位二进位即可。为了节省存储空间,并使处理简便,C语言又提供了一种数据结构,称为“位域”或“位段”。所谓“位域”是把一个字节中的二进位划分为几个不同的区域, 并说明每个区域的位数。每个域有一个域名,允许在程序中按域名进行操作。 这样就可以把几个不同的对象用一个字节的二进制位域来表示。
    一、位域的定义和位域变量的说明位域定义与结构定义相仿,其形式为: 

    struct 位域结构名 
    {
    
     位域列表
    
    };

    其中位域列表的形式为:

    类型说明符 位域名位域长度

    位域变量的说明与结构变量说明的方式相同。 可采用先定义后说明,同时定义说明或者直接说明这三种方式。例如:

    struct bs
    {
      int a:8;
      int b:2;
      int c:6;
    }data; 

    说明data为bs变量,共占两个字节。其中位域a占8位,位域b占2位,位域c占6位。对于位域的定义尚有以下几点说明:


    1. 一个位域必须存储在同一个字节中,不能跨两个字节。如一个字节所剩空间不够存放另一位域时,应从下一单元起存放该位域。也可以有意使某位域从下一单元开始。例如:

    struct bs
    {
        unsigned a:4
        unsigned b:5 /*从下一单元开始存放*/
        unsigned c:4
    }

    2. 由于位域不允许跨两个字节,因此位域的长度不能大于一个字节的长度

    3. 位域可以无位域名,这时它只用来作填充或调整位置。无名的位域是不能使用的。例如:

    复制代码
    struct k
    {
        int a:1
        int :2 /*无位域名,该2位不能使用*/
        int b:3
        int c:2
    }; 
    复制代码
  • 相关阅读:
    HDU 6464 /// 权值线段树
    HDU 6468 /// DFS
    HDU 6469 /// 二分
    HDU 6470 /// 矩阵快速幂
    USACO 2014 US Open Odometer /// 数位DP
    hdu5988(费用流,对数相乘做加法)
    对AC自动机+DP题的一些汇总与一丝总结 (2)
    对AC自动机+DP题的一些汇总与一丝总结 (1)
    POJ 1625 Censored ( Trie图 && DP && 高精度 )
    HDU 2243 ( Trie图 矩阵构造幂和 )
  • 原文地址:https://www.cnblogs.com/yuandongtao1989/p/6711109.html
Copyright © 2020-2023  润新知