⑴ 单片机资料里关于IO描述不太懂,求助!
表示连续位的范围(位域),例如书写成PORTA[7:5]就是代表由PORTA寄存器第5位到第7位组成的位域。
位域的概念可以参考C语言结构体的位域定义。
⑵ C语言中“位域”与“域宽”有什么区别。
有些信息在存储时,并不需要占用一个完整的字节,而只需占几个或一个二进制位。例如在存放一个开关量时,只有0和1
两种状态,用一位二进位即可。为了节省存储空间,并使处理简便,c语言又提供了一种数据结构,称为“位域”或“位段”。所谓“位域”是把一个字节中的二进位划分为几个不同的区域,并说明每个区域的位数。每个域有一个域名,允许在程序中按域名进行操作。这样就可以把几个不同的对象用一个字节的二进制位域来表示。一、位域的定义和位域变量的说明位域定义与结构定义相仿,其形式为:
struct
位域结构名
{
位域列表
};
其中位域列表的形式为:
类型说明符
位域名:位域长度
例如:
struct
bs
{
int
a:8;
int
b:2;
int
c:6;
};
⑶ 解释下位域,为什么要用位域,位域的好处
位域是指信息在存储时,并不需要占用一个完整的字节,
而只需占几个或一个二进制位。例如在存放一个开关量时,只有0和1
两种状态,
用一位二进位即可。为了节省存储空间,并使处理简便,C语言又提供了一种数据结构,称为"位域"或"位段"。所谓"位域"是把一个字节中的二进位划分为几
个不同的区域,
并说明每个区域的位数。每个域有一个域名,允许在程序中按域名进行操作。
这样就可以把几个不同的对象用一个字节的二进制位域来表示。
使用位域的好处是:
1.有些信息在存储时,并不需要占用一个完整的字节,
而只需占几个或一个二进制位。例如在存放一个开关量时,只有0和1
两种状态,
用一位二进位即可。这样节省存储空间,而且处理简便。
这样就可以把几个不同的对象用一个字节的二进制位域来表示。
2.可以很方便的利用位域把一个变量给按位分解。比如只需要4个大小在0到3的随即数,就可以只rand()一次,然后每个位域取2个二进制位即可,省时省空间。
⑷ 在单片机c语言中,结构体中的 U16 First_RF:1;是什么意思怎么解释 条件判断 if
U16 First_RF:1;是某个结构中定义了位域 First_RF,其宽度为1比特。
if (Flag.First_RF) 的意思是 如果 结构Flag的成员First_RF 非零。
⑸ 请问STM32全局位域(位段)怎么定义
你在.h文件下建立CtrlBit这个共用体类型,然后在对应的.c文件全局处定义这个共用体,最后在.h文件加extern 声明为外部变量就行了。
这里共用体跟结构体声明的格式是这样的喔:union CtrlBit{ ... };或者typedef union{ ... }CtrlBit; 在.c文件全局处定义union CtrlBit CtrlBit1;或者 CtrlBit CtrlBit1;(这个是typdef前提下),最后在.h文件进行外部变量声明extern union CtrlBit CtrlBit1;
⑹ 51单片机寄存器这个表格是什么意思
第一列,Bit,也就是位/位域。例如Bit[3:2]就是代表这个8位寄存器中的第3位和第2位。
第二列,Name,也就是位/位域的名称。
第三列,Reset,也就是复位后的默认值。
第四列,R/W,也就是该位/位域的读写属性。RO = Read Only只读,WO = Write Only只写,R/W = Read/Write可读可写。此外也有一些特殊的玩意儿例如W1C(写1清零)之类。
第五列,Description,功能描述。
⑺ 51单片机 bitzone 什么意思
字面意思就是,位域。
⑻ 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行用指针方式输出了这三个域的值。
⑼ 在单片机C语言中如何对变量的某一位进行操作或赋值。
在C语言中,一般有两种方法来操作位,一种是使用C语言提供的位运算操作符,一种是使用位域。
1、使用位域
在C语言中定义位域的一般格式如下:
struct位域结构名
{位域列表};
struct:在C语言中定义位域所使用的关键字是struct。
位域结构名:是一个C语言中的标识符,有字母、数字、下划线组成,而且第一个字符必须是字母或者下划线。
位域列表:组其中位域列表的形式为: 类型说明符 位域名:位域长度
下面的示例代码,通过位域来计算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;
}
2、使用位运算符
C语言中的位运算符有一个基本的常识,即只能操作整数,不能操作浮点数,因为浮点数是使用IEEE754编码的,使用位操作数没有任何意义。
C语言提供的位运算符列表:
&按位与如果两个相应的二进制位都为1,则该位的结果值为1,否则为0
|按位或两个相应的二进制位中只要有一个为1,该位的结果值为1
^按位异或若参加运算的两个二进制位值相同则为0,否则为1
~取反~是一元运算符,用来对一个二进制数按位取反,即将0变1,将1变0
<<左移用来将一个数的各二进制位全部左移N位,右补0
>>右移将一个数的各二进制位右移N位,移到右端的低位被舍弃,对于无符号数,高位补0