当前位置:首页 » 编程语言 » c语言位段的定义
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言位段的定义

发布时间: 2022-06-24 19:05:34

1. c语言 位段究竟是什么 通俗点

通常计算机最小处理单元基本就是byte字节了,就是八个二进制位。位段则是按计算机中真正的最小单位二进制位来存储处理数据,可以更高效的利用内存。在有些内存不是很宽裕的领域比如单片机上使用很广泛。

2. c语言位段

这个取决于编译器,编译器依赖于操作系统,操作系统依赖于硬件,根上还是有CPU读写数据的机器字长和地址总线来决定 的。。没有那么多限制的,举个例子, 我们随便定义一个位段,只有一个数据成员,占2个二进制位。 sizeof 的大小依然是4,如下代码:

#include<stdio.h>
structbit_record{
unsignedintx:2;
}br;
intmain()
{
printf("%d %d ",sizeof(bit_record),sizeof(br));
return0;
}

事实上你把它当成一个struct结构体就好了,不用太较真。。比如你在编写IEEE754浮点数编码的时候,经常用到位域,它的结构如下代码所示:

typedefstructFP_SINGLE
{
unsigned__int32fraction:23;//这里也早超过一个字节。。
unsigned__int32exp:8;
unsigned__int32sign:1;
}fp_single;
typedefstructFP_DOUBLE
{
unsigned__int64fraction:52;//这里早超过int类型的,需要用扩展int类型
unsigned__int64exp:11;
unsigned__int64sign:1;
}fp_double;

3. c语言中的位段

bit_field.bit0,并不是指针
(volatile bit_field*)这个是指针
(*(volatile bit_field*))这是一对互逆操作,相当于volatile bit_field

4. C语言位段我买的一本书说位段必须被定义int unsigned 和signed类型的。这句话正确

这话没有错,就是只能定义为整型的意思,包括int、unsigned、signed等。由于早期的C的int型是2字节,所以没有short类型,后期的编译器升级到int为4字节了,在小数据运算时为了节约内存空间,就有了short类型,它是2字节的整型数,所以你定义为short也没有错。实际上定义成char型也应该是可以的,因为char型的实质是单字节整型,在C中与int型可以通用。

5. 【C语言】unsigned int : 4;是什么意思

意思是让int值占4位,准确的写法应该是:unsigned int b:4;意思是让b占四位,unsigned int b:8;就是让b占8位,是为了内存对齐而写的,一些操作系统要求必须8位对齐,那一个int如果不满8位,就要强制让他占8位,浪费一些空间而已。

6. c语言是怎样实现位段的

C语言提供了位域。
摘自<谭书>
位域

有些信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位。例如在存放一个开关量时,只有0和1 两种状态, 用一位二进位即可。为了节省存储空间,并使处理简便,C语言又提供了一种数据结构,称为“位域”或“位段”。所谓“位域”是把一个字节中的二进位划分为几个不同的区域, 并说明每个区域的位数。每个域有一个域名,允许在程序中按域名进行操作。 这样就可以把几个不同的对象用一个字节的二进制位域来表示。一、位域的定义和位域变量的说明位域定义与结构定义相仿,其形式为:
struct 位域结构名
{ 位域列表 };
其中位域列表的形式为: 类型说明符 位域名:位域长度
例如:
struct bs
{
int a:8;
int b:2;
int c:6;
};
位域变量的说明与结构变量说明的方式相同。 可采用先定义后说明,同时定义说明或者直接说明这三种方式。例如:
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 :0 /*空域*/
unsigned b:4 /*从下一单元开始存放*/
unsigned c:4
}
在这个位域定义中,a占第一字节的4位,后4位填0表示不使用,b从第二字节开始,占用4位,c占用4位。

2. 由于位域不允许跨两个字节,因此位域的长度不能大于一个字节的长度,也就是说不能超过8位二进位。

3. 位域可以无位域名,这时它只用来作填充或调整位置。无名的位域是不能使用的。例如:
struct k
{
int a:1
int :2 /*该2位不能使用*/
int b:3
int c:2
};
从以上分析可以看出,位域在本质上就是一种结构类型, 不过其成员是按二进位分配的。

二、位域的使用位域的使用和结构成员的使用相同,其一般形式为: 位域变量名·位域名 位域允许用各种格式输出。
main(){
struct bs
{
unsigned a:1;
unsigned b:3;
unsigned c:4;
} bit,*pbit;
bit.a=1;
bit.b=7;
bit.c=15;
printf("%d,%d,%d\n",bit.a,bit.b,bit.c);
pbit=&bit;
pbit->a=0;
pbit->b&=3;
pbit->c|=1;
printf("%d,%d,%d\n",pbit->a,pbit->b,pbit->c);
}
上例程序中定义了位域结构bs,三个位域为a,b,c。说明了bs类型的变量bit和指向bs类型的指针变量pbit。这表示位域也是可以使用指针的。
程序的9、10、11三行分别给三个位域赋值。( 应注意赋值不能超过该位域的允许范围)程序第12行以整型量格式输出三个域的内容。第13行把位域变量bit的地址送给指针变量pbit。第14行用指针方式给位域a重新赋值,赋为0。第15行使用了复合的位运算符"&=", 该行相当于: pbit->b=pbit->b&3位域b中原有值为7,与3作按位与运算的结果为3(111&011=011,十进制值为3)。同样,程序第16行中使用了复合位运算"|=", 相当于: pbit->c=pbit->c|1其结果为15。程序第17行用指针方式输出了这三个域的值。

7. c语言中如何定义一个bit

1、在c语言中定义bit型变量,可以使用位域来自定义。
位域的定义和位域变量的说明位域定义与结构定义相仿,其形式为:
struct 位域结构名
{ 位域列表 };
其中位域列表的形式为: 类型说明符 位域名:位域长度;

2、示例:通过位域来计算IEEE754浮点数标准中,单精度浮点数的最大值、最小值以及最小弱规范数。

#include<stdio.h>
typedefstructFP_SINGLE
{
unsigned__int32fraction:23;
unsigned__int32exp:8;
unsigned__int32sign:1;
}fp_single;
intmain()
{
floatx;
fp_single*fp_s=(fp_single*)&x;
fp_s->sign=0;
fp_s->exp=0xfe;
fp_s->fraction=0x7fffff;
printf("float最大数:%le ",(double)x);
fp_s->sign=0;
fp_s->exp=0x1;
fp_s->fraction=0x0;
printf("float最小数:%le ",(double)x);
fp_s->sign=0;
fp_s->exp=0;
fp_s->fraction=0x1;
printf("float最小弱规范数:%le ",(double)x);
return0;
}

8. c语言位变量定义

在c语言中定义bit型变量,可以使用位域来自定义。
位域的定义和位域变量的说明位域定义与结构定义相仿,其形式为:
struct 位域结构名
{ 位域列表 };
其中位域列表的形式为: 类型说明符 位域名:位域长度;
示例:通过位域来计算IEEE754浮点数标准中,单精度浮点数的最大值、最小值以及最小弱规范数。
#include <stdio.h>
typedef struct FP_SINGLE
{
unsigned __int32 fraction : 23;
unsigned __int32 exp : 8;
unsigned __int32 sign : 1;
} fp_single;
int main()
{
float x;
fp_single * fp_s = (fp_single *)&x;
fp_s->sign = 0;
fp_s->exp = 0xfe;
fp_s->fraction = 0x7fffff;
printf ("float 最大数: %le\n",(double)x);
fp_s->sign = 0;
fp_s->exp = 0x1;
fp_s->fraction = 0x0;
printf ("float 最小数: %le\n",(double)x);
fp_s->sign = 0;
fp_s->exp = 0;
fp_s->fraction = 0x1;
printf ("float 最小弱规范数:%le\n\n",(double)x);
return 0;
}

9. c语言中位段和结构体

由右至左指的是位在一个unsigned里的存储位置,如果这里的unsigned是16位

那么a占低2位,b占低3位,c占低4位

高 ——> 低
|16|15|14|13|12|11|10|9|8|7|6|5|4|3|2|1|

所以data.a = 8,由于a只占2位,最大能保存3,所以溢出,data.a = 0,最后结果是输出2

10. C语言的结构体位定义问题

1.我认为uint16_t这是你定义的一个新类型
typedef unsigned short uint16_t; /*就是定义无符号短整型为 uint16_t*/
typedef unsigned char uint8_y; /*定义无符号char型为 uint8_t*/
两个结构体中只有这地方不同,对于第二个结构提,因为char型,只有8位,当超过8bit时,会自动的申请新的字节进行存储,因此第二个字节使用2个1字节存储,而第一个结构体使用1个2字节存储。

2.对于冒号,这是C语言中位域的用法,有些信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位。
例如在存放一个开关量时,只有0和1 两种状态, 用一位二进位即可。为了节省存储空间,并使处理简便。所谓“位域”是把一个字节中的二进位划分为几个不同的区域, 并说明每个区域的位数。每个域有一个域名,允许在程序中按域名进行操作。 这样就可以把几个不同的对象用一个字节的二进制位域来表示
具体例子如下:
#include <stdio.h>

typedef unsigned char u8;

/*定义新类型,这个新类型由4部分组成,每部分只占无符号char型8bit
中的几bit*/
typedef struct _my_bit_
{
u8 one:1;
u8 two:2;
u8 three:3;
u8 four:2;
}mybitfiled;

int main()
{
mybitfiled mybit;
/*注意位域分配的位个数,例如one只分配了1bit,那么mybit.one只能为1或0,
如果输入2的话,那么会提示将多余部分给删掉的,意思只能取最后1bit的信息*/

mybit.one = 1;
mybit.two = 2;
mybit.three = 3;
mybit.four = 1;
printf("sizeof(mybit) = %d,%d %d %d %d\n",sizeof(mybit),mybit.one,mybit.two,mybit.three,mybit.four);

return 0;
}