位置:首页 > 其它资料

c语言中bit的用法是什么意思

2020-02-04发布者:郝悦皓大小:68.81 KB 下载:0

c 语言中 bit 的用法:bit 和 sbit 都是 C51 扩展的变量类型 bit 和 int char 之类的差不多,只不过 char=8 位, bit=1 位而已。都是变 量,编译器在编译过程中分配地址。除非你指定,否则这个地址是随机的。 这个地址是整个可寻址空间,RAM+FLASH+扩展空间。bit 只有 0 和 1 两种值, 意义有点像 Windows 下 VC 中的 BOOL。 sbit 是对应可位寻址空间的一个位,可位寻址区:20H~2FH。一旦用 了 sbi xxx = REGE^6 这样的定义,这个 sbit 量就确定地址了。sbit 大部分是 用在寄存器中的,方便对寄存器的某位进行操作的。 c 语言中 bit 的用法:bit 位标量 bit 位标量是 C51 编译器的一种扩充数据类型,利用它可定义一个位标 量,但不能定义位指针,也不能定义位数组。它的值是一个二进制位,不是 0 就是 1,类似一些高级语言中的 Boolean 类型中的 True 和 False。 c 语言中 bit 的用法:sfr 特殊功能寄存器 sfr 也是一种扩充数据类型,点用一个内存单元,值域为 0~255。利用 它可以访问 51 单片机内部的所有特殊功能寄存器。如用 sfr P1 = 0×90 这一 句 定 P1 为 P1 端 口 在 片 内 的 寄 存 器 , 在 后 面 的 语 句 中 我 们 用 以 用 P1 = 255(对 P1 端口的所有引脚置高电平)之类的语句来操作特殊功能寄存器。 sfr P1 = 0×90; //定义 P1 I/O 口,其地址 90H sfr 关键定后面是一个要定义的名字,可任意选取,但要符合标识符的命名 规则,名字最好有一定的含义如 P1 口可以用 P1 为名,这样程序会变的好读好 多.等号后面必须是常数,不允许有带运算符的表达式,而且该常数必须在特殊 功能寄存器的地址范围之内(80H-FFH),具体可查看附录中的相关表. sfr 是定义 8 位的特殊功能寄存器而 sfr16 则是用来定义 16 位特殊功能 寄存器, 如 8052 的 T2 定时器,可以定义为: sfr16 T2 = 0xCC; //这里定义 8052 定时器 2,地址为 T2L=CCH,T2H=CDH 用 sfr16 定义 16 位特殊功能寄存器时,等号后面是它的低位地址,高位地 址一定要位于物 理低位地址之上.注意的是不能用于定时器 0 和 1 的定义. sbit 可定义可位寻址对象.如访问特殊功能寄存器中的某位.其实这样应 用是经常要 用的如要访问 P1 口中的第 2 个引脚 P1.1.我们可以照以下的方法去定义: (1) sbit 位变量名=位地址 sbit P1_1 = Ox91; 这样是把位的绝对地址赋给位变量.同 sfr 一样 sbit 的位地址必须位于 80H-FFH 之间. (2) sbit 位变量名=特殊功能寄存器名^位位置 sft P1 = 0×90; sbit P1_1 = P1 ^ 1; //先定义一个特殊功能寄存器名再指定位变量名所在 的位置,当可 寻址位位于特殊功能寄存器中时可采用这种方法 (3) sbit 位变量名=字节地址^位位置 sbit P1_1 = 0×90 ^ 1; 这种方法其实和 2 是一样的,只是把特殊功能寄存器的位址直接用常数表 示. 在 C51 存储器类型中提供有一个 bdata 的存储器类型,这个是指可位寻址的数据 存储器,位于单 片机的可位寻址区中,可以将要求可位录址的数据定义为 bdata,如: unsigned char bdata ib; //在可位录址区定义 ucsigned char 类型的变量 ib int bdata ab[2]; //在可位寻址区定义数组 ab[2],这些也称为可寻址位对 象 sbit ib7=ib^7 //用关键字 sbit 定义位变量来独立访问可寻址位对象的其 中一位 sbit ab12=ab[1]^12; 操作符”^”后面的位位置的最大值取决于指定的基址类型,char0-7,int015,long0-31. sfr 并标准 C 语言的关键字,而是 Keil 为能直接访问 80C51 中的 SFR 而 提供了一个新 的关键词,其用法是: sfrt 变量名=地址值。 2)符号 P1_0 来表示 P1.0 引脚。 在 C 语言里,如果直接写 P1.0,C 编译器并不能识别,而且 P1.0 也不 是一个合法的 C 语言变量名,所以得给它另起一个名字,这里起的名为 P1_0,可是 P1_0 是不是就是 P1.0 呢?你这么认为,C 编译器可不这么认为,所以必须给它们建立联系,这 里使用了 Keil C 的关键字 sbit 来定义,sbit 的用法有三种: 第一种方法:sbit 位变量名=地址值 第二种方法:sbit 位变量名=SFR 名称^变量位地址值 第三种方法:sbit 位变量名=SFR 地址值^变量位地址值 如定义 PSW 中的 OV 可以用以下三种方法: sbit OV=0xd2 (1)说明:0xd2 是 OV 的位地址值 sbit OV=PSW^2 (2)说明:其中 PSW 必须先用 sfr 定义好 sbit OV=0xD0^2 (3)说明:0xD0 就是 PSW 的地址值 因此这里用 sfr P1_0=P1^0;就是定义用符号 P1_0 来表示 P1.0 引脚,如 果你愿意也可以 起 P10 一类的名字,只要下面程序中也随之更改就行了。 *AT89C51 的特殊功能寄存器表请看附录二 c 语言中 bit 的用法:sfr16 16 位特殊功能寄存器 sfr16 占用两个内存单元,值域为 0~65535。sfr16 和 sfr 一样用于操作 特殊功能寄存器,所不同的是它用于操作占两个字节的寄存器,好定时器 T0 和 T1。 c 语言中 bit 的用法:sbit 可录址位 sbit 同位是 C51 中的一种扩充数据类型,利用它可以访问芯片内部的 RAM 中的可寻址位或特殊功能寄存器中的可寻址位。如先前我们定义了 sfr P1 = 0×90; //因 P1 端口的寄存器是可位寻址的,所以我们可以定义 sbit P1_1 = P1^1; //P1_1 为 P1 中的 P1.1 引脚 //同样我们可以用 P1.1 的地址去写,如 sbit P1_1 = 0×91; 这样我们在以后的程序语句中就可以用 P1_1 来对 P1.1 引脚进行读写操 作了。通常这些可以直接使用系统提供的预处理文件,里面已定义好各特殊 功能寄存器的简单名字,直接引用可以省去一点时间,我自己是一直用的。 当然您也可以自己写自己的定义文件,用您认为好记的名字。
温馨提示:如果当前文档预览出现乱码或未能正常浏览,请先下载原文档进行浏览。
发表评论(共0条评论)
请自觉遵守互联网相关政策法规,评论内容只代表网友观点,发表审核后显示!

下载需知:

1 该文档不包含其他附件(如表格、图纸),本站只保证下载后内容跟在线阅读一样,不确保内容完整性,请务必认真阅读

2 除PDF格式下载后需转换成word才能编辑,其他下载后均可以随意编辑修改

3 有的标题标有”最新”、多篇,实质内容并不相符,下载内容以在线阅读为准,请认真阅读全文再下载

4 该文档为会员上传,版权归上传者负责解释,如若侵犯你的隐私或权利,请联系客服投诉

返回顶部