C语言中对引的读写操作 sbit的三种用法

控制/MCU

1883人已加入

描述

     在C语言里。如果直接写P1.O,C编译器并不能识别,而且P1.O也不是一个合法的C语言变量名,所以得给它另起一个名字,比如起名为P1—0,可是P1—0是不是就是P10呢? 

  可以这么认为,C编译器可不这么认为,所以必须给它们建立联系,这里使用了KeilC的关键字sbit。来定义。sbit是C51中的一种扩充数据类型,利用它可以访问芯片内部的RAM中的可寻址位或特殊功能寄存器中的可寻址位。

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

  sbit的用法有三种:

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

  如定义PSW中的OV可以用以下三种方法:

  (1)sbitOV=0xd2说明:
  
  0xd2是OV的位地址值,这样是把位的绝对地址赋给位变量。
  
  sbit的位地址必须位于80F_一FFI-1之间。
  
  (2)sbitOV=PSW^2说明:
  
  其中PSW必须先用sfr定义好,先定义一个特殊功能寄存器名再指定位变量名所在的位置,当可寻址位位于特殊功能寄存器中时可采用这种方法。
  
  (3)sbitOV=0xDO^2说明:
  
  0xDO就是PSW的地址值。
  
  因此这里用sbitP1—0=P1^0就是定义用符号P1一O来表示P1.0引脚,当然,如果你愿意也可以用P10一类的名字,只要下面程序中也随之更改就行了。同样我们可以用P1.1的地址去写,如sbjtP1—1=Ox91:这样在以后的程序语句中就可以用P1—1来对P1.1引脚进行读写操作了。
  
  通常我们可以直接使用系统提供的预处理文件里面已定义好的各特殊功能寄存器的简单名字,直接引用可以省去一点时间。当然您也可以自己写自己的定义文件,用您认为好记的名字。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分