sbit 使用方法

1. 使用方法

 sbit是定义特殊功能寄存器的位变量。bit和sbit都是C51扩展的变量类型。典型应用是:sbit P0_0=P0^0;//即定义P0_0为P0口的第1位,以便进行位操作。bit和int char之类的差不多,只不过char=8位, bit=1位而已。都是变量,编译器在编译过程中分配地址。

第一种方法:sbit位变量名=地址值

  (1)sbitOV=0xd2说明:      0xd2是OV的位地址值,这样是把位的绝对地址赋给位变量。      sbit的位地址必须位于80F_一FFI-1之间。   

第二种方法:sbit位变量名=SFR名称^变量位地址值

 (2)sbitOV=PSW^2说明:      其中PSW必须先用sfr定义好,先定义一个特殊功能寄存器名再指定位变量名所在的位置,当可寻址位位于特殊功能寄存器中时可采用这种方法。     

第三种方法:sbit位变量名=SFR地址值^变量位地址值

 (3)sbitOV=0xDO^2说明:      0xDO就是PSW的地址值。      因此这里用sbit  P1—0=P1^0就是定义用符号P1一O来表示P1.0引脚,当然,如果你愿意也可以用P10一类的名字,只要下面程序中也随之更改就行了。同样我们可以用P1.1的地址去写,如sbit P1—1=Ox91:这样在以后的程序语句中就可以用P1—1来对P1.1引脚进行读写操作了

2.  注意事项

不同编译器采用不同版本的C标准,因此细微之处有些差别。例如Keil C51是基于C90的,局部变量声明只允许放在函数实体语句之前;

'''keil'''  sbit 必须在函数声明在函数 外

sbit 使用方法_第1张图片

sbit 使用方法_第2张图片 

sbit声明的部分是编译器预处理的部分,就是为了给寄存器(位或字节)取个别名,是在函数没有编译之前必须完成的,放在主函数中就是编译中要处理的内容了,对于那些符号地址,C编译器不认识,有的名字也不允许(如P1.1),必须在编译之前进行替代,就是sbit声明,替代的内容为相应单片机寄存器的头文件里边定义的,如REG51.H;

sbit声明位成员,视作全局。sbit声明位成员建议放在头文件中。
全局变量声明在函数体外,引用之前。
局部变量声明在函数体内,引用之前。

你可能感兴趣的:(硬件开发,单片机)