C语言啥是位段,位段的定义求答案
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言啥是位段,位段的定义求答案相关的知识,希望对你有一定的参考价值。
位段(bit-field)是以位为单位来定义结构体(或联合体)中的成员变量所占的空间。含有位段的结构体(联合体)称为位段结构。采用位段结构既能够节省空间,又方便于操作。
位段的定义格式为:
type [var]: digits
其中type只能为int,unsigned int,signed int三种类型(int型能不能表示负数视编译器而定)。位段名称var是可选参数,即可以省略。digits表示该位段所占的二进制位数。
那么定义一个位段结构可以像下面这段代码去定义:
struct nodeunsigned int a:4; //位段a,占4位
unsigned int :0; //无名位段,占0位
unsigned int b:4; //位段b,占4位
int c:32; //位段c,占32位
int :6; //无名位段,占6位
;
使用位段需注意一下几点:
1)位段的类型只能是int,unsigned int,signed int三种类型,不能是char型或者浮点型;
2)位段占的二进制位数不能超过该基本类型所能表示的最大位数,比如在VC中int是占4个字节,那么最多只能是32位;
3)无名位段不能被访问,但是会占据空间;
4)不能对位段进行取地址操作;
5)若位段占的二进制位数为0,则这个位段必须是无名位段,下一个位段从下一个位段存储单元(这里的位段存储单元经测试在VC环境下是4个字节)开始存放;
6)若位段出现在表达式中,则会自动进行整型升级,自动转换为int型或者unsigned int。
7)对位段赋值时,最好不要超过位段所能表示的最大范围,否则可能会造成意想不到的结果。
8)位段不能出现数组的形式。
参考技术A 位段则是一种特殊的结构体成员,这些成员允许以位为单位进行定义和存储,可以作为独立的量参与操作和运算。例如 上述控制字的例子中,可以采用位段的方法,将控制字分为两个位段,作为两个成员来使用。只需定义本回答被提问者采纳 参考技术B 有些信息在存储时,不需要占用一个完整的字节,而只需占几个或一个二进制位。
例如,在存放一个开关量的时候,只有0和1两种状态,用一位二进制位即可。为了节省存储空间,并使处理简便,C语音又提供了一种数据结构,称为“位域”或“位段”。所谓位段是把一个字节中的二进制位划分为几个不同的区域,并说明每个区域的位数。每个域都有一个域名,允许在程序中按域名进行操作。这样就可以把几个不同的对象用一个字节的二进制位域来表示。
手打勿喷。
以上是关于C语言啥是位段,位段的定义求答案的主要内容,如果未能解决你的问题,请参考以下文章