C51位变量bit定义

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C51位变量bit定义相关的知识,希望对你有一定的参考价值。

该怎么定义啊?例如将P2^1定义成一个位变量

bit 是定义一个位变量。
例如:
void main(void)

bit bIsBit ;
bIsBit=1;
if( bIsBit == 1 )

;//如果位变量=1时。

else

;//如果位变量=0时。

while( bIsBit==0 )

;//如果位变量=0时,死循环。

参考技术A P2_1 bit p2.1

P2_1 你要定义的变量名
P2.1 c51单片机,P2口的第2个引脚,第一个引脚是P1.0

就这样定义....
参考技术B sbit led=P2^1;本回答被提问者采纳

C语言啥是位段,位段的定义求答案

 位段(bit-field)是以位为单位来定义结构体(或联合体)中的成员变量所占的空间。含有位段的结构体(联合体)称为位段结构。采用位段结构既能够节省空间,又方便于操作。

     位段的定义格式为:

     type  [var]: digits

    其中type只能为int,unsigned int,signed int三种类型(int型能不能表示负数视编译器而定)。位段名称var是可选参数,即可以省略。digits表示该位段所占的二进制位数。

   那么定义一个位段结构可以像下面这段代码去定义:

struct node

    unsigned 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语音又提供了一种数据结构,称为“位域”或“位段”。所谓位段是把一个字节中的二进制位划分为几个不同的区域,并说明每个区域的位数。每个域都有一个域名,允许在程序中按域名进行操作。这样就可以把几个不同的对象用一个字节的二进制位域来表示。
手打勿喷。

以上是关于C51位变量bit定义的主要内容,如果未能解决你的问题,请参考以下文章

C51中bit 是啥意思,麻烦各位

C51中,用sbit定义位变量,是否就存放在单片机的可位寻址区(0x20--0x2F)呢?

C51

c 语言中 bit与sbit的区别

sbit的定义

位变量bit和sbit有啥用?