资源描述:
《C语言关键字用法.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、c语言中bit和sbit的区别 c语言中bit和sbit的区别:1.bit和sbit都是C51扩展的变量类型。 bit和intchar之类的差不多,只不过char=8位,bit=1位而已。都是变量,编译器在编译过程中分配地址。除非你指定,否则这个地址是随机的。这个地址是整个可寻址空间,RAM+FLASH+扩展空间。bit只有0和1两种值,意义有点像Windows下VC中的BOOL。 sbit是对应可位寻址空间的一个位,可位寻址区:20H~2FH。一旦用了sbixxx=REGE^6这样的定义,这个sbit量就确定地
2、址了。sbit大部分是用在寄存器中的,方便对寄存器的某位进行操作的。2.bit位标量 bit位标量是C51编译器的一种扩充数据类型,利用它可定义一个位标量,但不能定义位指针,也不能定义位数组。它的值是一个二进制位,不是0就是1,类似一些高级语言中的Boolean类型中的True和False。3.sfr特殊功能寄存器 sfr也是一种扩充数据类型,点用一个内存单元,值域为0~255。利用它可以访问51单片机内部的所有特殊功能寄存器。如用sfrP1=0×90这一句定P1为P1端口在片内的寄存器,在后面的语句中我们用以用P1
3、=255(对P1端口的所有引脚置高电平)之类的语句来操作特殊功能寄存器。sfrP1=0×90;//定义P1I/O口,其地址90H sfr关键定后面是一个要定义的名字,可任意选取,但要符合标识符的命名规则,名字最好有一定的含义如P1口可以用P1为名,这样程序会变的好读好多.等号后面必须是常数,不允许有带运算符的表达式,而且该常数必须在特殊功能寄存器的地址范围之内(80H-FFH),具体可查看附录中的相关表. sfr是定义8位的特殊功能寄存器而sfr16则是用来定义16位特殊功能寄存器,如8052的T2定时器,可以
4、定义为:sfr16T2=0xCC;//这里定义8052定时器2,地址为T2L=CCH,T2H=CDH用sfr16定义16位特殊功能寄存器时,等号后面是它的低位地址,高位地址一定要位于物理低位地址之上.注意的是不能用于定时器0和1的定义.sbit可定义可位寻址对象.如访问特殊功能寄存器中的某位.其实这样应用是经常要用的如要访问P1口中的第2个引脚P1.1.我们可以照以下的方法去定义:(1)sbit位变量名=位地址sbitP1_1=Ox91;这样是把位的绝对地址赋给位变量.同sfr一样sbit的位地址必须位于80H-FFH之间.(2)sbit
5、位变量名=特殊功能寄存器名^位位置sftP1=0×90;sbitP1_1=P1^1;//先定义一个特殊功能寄存器名再指定位变量名所在的位置,当可寻址位位于特殊功能寄存器中时可采用这种方法(3)sbit位变量名=字节地址^位位置sbitP1_1=0×90^1;这种方法其实和2是一样的,只是把特殊功能寄存器的位址直接用常数表示.在C51存储器类型中提供有一个bdata的存储器类型,这个是指可位寻址的数据存储器,位于单片机的可位寻址区中,可以将要求可位录址的数据定义为bdata,如:unsignedcharbdataib;//在可位录址区定义u
6、csignedchar类型的变量ibintbdataab[2];//在可位寻址区定义数组ab[2],这些也称为可寻址位对象sbitib7=ib^7//用关键字sbit定义位变量来独立访问可寻址位对象的其中一位sbitab12=ab[1]^12;操作符”^”后面的位位置的最大值取决于指定的基址类型,char0-7,int0-15,long0-31.sfr并标准C语言的关键字,而是Keil为能直接访问80C51中的SFR而提供了一个新的关键词,其用法是:sfrt变量名=地址值。2)符号P1_0来表示P1.0引脚。在C语言里,如果直接写P1.0
7、,C编译器并不能识别,而且P1.0也不是一个合法的C语言变量名,所以得给它另起一个名字,这里起的名为P1_0,可是P1_0是不是就是P1.0呢?你这么认为,C编译器可不这么认为,所以必须给它们建立联系,这里使用了KeilC的关键字sbit来定义,sbit的用法有三种:第一种方法:sbit位变量名=地址值第二种方法:sbit位变量名=SFR名称^变量位地址值第三种方法:sbit位变量名=SFR地址值^变量位地址值如定义PSW中的OV可以用以下三种方法:sbitOV=0xd2(1)说明:0xd2是OV的位地址值sbitOV=PSW^2(2)说
8、明:其中PSW必须先用sfr定义好sbitOV=0xD0^2(3)说明:0xD0就是PSW的地址值因此这里用sfrP1_0=P1^0;就是定义用符号P1_0来表示P1.0引脚,如果你愿意也可以