c 语言中 bit与sbit的区别

如题所述

不是C语言里的,而是C51里面的。

区别在于功能不同:

bit:是变量类型,相当于boot 只占一个位,最多可定128个bit变量。

sbit:是给可位寻址的变量(或特殊功能寄存器)的某一个位定个别名,不另占空间。

扩展资料:

单片机中C语言sbit使用方法——

1、bit位标量。

bit位标量是c51编译器的一种扩充数据类型,利用它可以定义一个位标量,但是不能定义位指针,也不能定义位数组。它的值是一个二进制位,不是0或1,类似boolean中的true和false。

2、sfr特殊功能寄存器。

sfr也是一种扩充数据类型,点用一个内存单元,值域为0~255.利用它可以访问51单片机内部的所有特殊功能寄存器。如果sfr P1 = 0x90,这一句定P1为P1端口在片内的寄存器,在后面的语句中我们可以用P1=255(对P1端口的所有的引脚置高电平)之类的语句来操作特殊功能寄存器。

sfr是定义8位的特殊功能寄存器而sfr16 则是定义16位特殊功能寄存器。


温馨提示:内容为网友见解,仅供参考
第1个回答  2019-07-09

一、意思不同

bit是变量类型,相当于boot 只占一个位,最多可定128个bit变量,sbit是给可位寻址的变量(或特殊功能寄存器)的某一个位定个别名,不另占空间。

如:

bit YesOrNo; //定义bit型变量 占用bdata区的一个位。

sbit P0_1 = P0^1; //申明一个引用名 P0_1 指向端口P0的1号接脚,不会额外分配空间。

二、用法不同

bit,sbit是KEIL c51里面扩展的数据类型,BIT表示一位二进制类型的数据,只有0,1两种取值

SBIT表示一位字符,sbit是位定义,这个定义只有51内核的单片机才有,一般用于51端口的位操作,一个P口有8位,sbit就可以定义一个通俗的名字来描述一端口8位中的其中一位如sbit LED=P0^1; sbit key=P0^2;等等,这样当你使用LED或者KEY时就相当于对P0.1和P0.2操作了。

三、用处不同

sfr也是一种扩充数据类型,点用一个内存单元,值域为0~255。利用它可以访问51单片机内部的所有特殊功能寄存器。如用sfr P1 = 0×90这一句定P1为P1端口在片内的寄存器,用以用P1 = 255(对P1端口的所有引脚置高电平)之类的语句来操作特殊功能寄存器。




本回答被网友采纳
第2个回答  2019-10-02

bit和sbit这两者不是C语言里面的,而是C51里面的;

bit和sbit的区别在于两者功能不同,具体如下:

bit是变量类型,相当于boot 只占一个位,最多可定128个bit变量,而sbit是给可位寻址的变量的某一个位定个别名,不另占空间;

扩展资料:

bit定义:

比特是英文 binary digit的缩写,比特是表示信息的最小单位,是二进制数的一位包含的信息或2个选项中特别指定1个的需要信息量,一般来说,n比特的信息量可以表现出2的n次方种选择;

sbit定义:

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

参考资料来源:百度百科-sbit

参考资料来源:百度百科-bit

本回答被网友采纳
第3个回答  推荐于2017-09-14
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量就确定地址了。

bit和sbit的最大区别在于,bit是定义一个变量;sbit经常用在寄存器中的,方便对寄存器的某位进行操作。

参考资料:http://zhidao.baidu.com/question/72536362.html

本回答被提问者采纳
第4个回答  2017-12-19
  bit : 编译时分配空间 sbit 只能在外部定义全局变量。 sfr(特殊功能寄存器)的bit。SFR是系统指定的内存地址。   bit 动态分配的,有编译器来指定内存地址。   bit和sbit都是C51扩展的变量类型。   sbit 要在最外面定义,就是说必须定义成外部变量.sbit定义的是SFR(特殊功能寄存器)的bit   sbit更像是类型定义,不像是变量定义。   sbit: 指示说明性说明   bit 可以在外部或内部定义。   bit和int char之类的差不多,只不过char=8位, bit="1位而已"。都是变量,编译器在编译过程中分配地址。除非你指定,否则这个地址是随机的。这个地址是整个可寻址空间,RAM+FLASH+扩展空间。bit只有0和1两种值,意义有点像Windows下VC中的BOOL。   bit是编译器在的可寻址区分配的一个位变量,是不定的,不是绝对地址目标。   所有可位寻址的位都可由sbit指定,这包括可位寻址区和SFR中的位。   sbit是对应可位寻址空间的一个位,可位寻址区:20H~2FH。一旦用了sbi xxx = REGE^6这样的定义,这个sbit量就确定地址了。sbit大部分是用在寄存器中的,方便对寄存器的某位进行操作的。   sbit位寄存器是可位寻址的绝对地址目标,定义后编译器是不会改变位置的。

c语言中bit与sbit的区别
1. 在C语言中,"bit"和"sbit"的定义和使用场景存在显著差异。2. "bit"作为基本的数据单位,用于表示二进制位,其值只能是0或1。3. "sbit"则主要用于嵌入式编程,表示特殊的位字段,通常与硬件寄存器的特定位相关。4. "bit"是计算机信息处理的基础,是所有数据类型的组成部分。5. "sbit"在嵌入式...

c 语言中 bit与sbit的区别
不是C语言里的,而是C51里面的。区别在于功能不同:bit:是变量类型,相当于boot 只占一个位,最多可定128个bit变量。sbit:是给可位寻址的变量(或特殊功能寄存器)的某一个位定个别名,不另占空间。

c语言中bit与sbit的区别
在C语言中,bit和sbit的主要区别在于它们的定义和使用场景。简单来说,bit是标准的数据单位,用于表示二进制位;而sbit则常用于表示特殊的位场标记或属性标志。其中,“bit”指的是一个二进制位,它只能表示一个二进制的值,即“0”或“1”。而“sbit”通常在嵌入式编程中出现,用于表示一个特殊的位...

bit与sbit定义的位变量有什么区别
定义方式、存储方式等区别。1、定义方式:“bit”是一种普通的位变量定义方式,用于表示一个单独的位。“sbit”是特殊功能寄存器位的缩写,用于表示一个特殊功能寄存器中的位。2、存储方式:“bit”类型的位变量通常使用一个字节(8位)的内存空间来存储,即使只需要一个位的存储空间。“sbit”类型的位...

c 语言中 bit与sbit的区别
`bit`和`sbit`的主要区别在于,`bit`通常用于定义一般的变量,而`sbit`则专门用于寄存器操作,这使得对寄存器特定位的直接访问变得更为方便,从而提高了程序的执行效率和精确度。因此,在编程时,选择使用`bit`还是`sbit`,应基于是否需要直接访问特定位置以及是否需要指定变量地址的需求。

C语言中sbit是什么意思,与bit有什么区别?
1.C语言中没有sbit关键字,这个是编译器里面的关键字。 sbit应该是keil c51中的关键字,表示位寄存器。一个端口8位,用这个关键字,可以单个位操作。2.bit和sbit都是C51扩展的变量类型。典型应用是:sbit P0_0=P0^0;\/\/即定义P0_0为P0口的第1位,以便进行位操作。bit和int char之类的差不多,...

bit与sbit定义的位变量有什么区别
而 "sbit" 关键字用于指定特殊功能寄存器中的一个位。2. 存储方式:"bit" 类型的位变量通常会在内存中占用一个完整的字节(8位),即使它只需要存储一个位。相比之下,"sbit" 类型的位变量则利用特殊功能寄存器中的一个位来存储,这些寄存器是硬件的一部分,每个位都与特定的硬件功能相对应。

c 语言中 bit与sbit的区别
在C51语言中,bit和sbit是两种扩展的变量类型,它们在使用上有一些显著的区别。bit可以类比于C语言中的int或char,其中char通常占用8位,而bit则占用单个位,即1位。它们本质上都是变量,编译时会被分配内存地址,但默认情况下,这个地址是随机的,涵盖RAM、FLASH以及可能的扩展存储空间。bit变量的值仅限...

sbitbit和sbit区别
在C51的扩展中,bit和sbit都是特殊的变量类型,但它们的使用方式和特性有所不同。sbit是一种特殊的变量类型,它要求在外部定义,即作为外部变量来使用。sbit实际上定义的是SFR(特殊功能寄存器)中的一个位,它更像是一个类型说明,而非普通变量的定义。相比之下,bit可以被定义在外部或内部,它与int...

请简述c51新增数据类型bit和sbit之间的区别
与bit不同的是,sbit类型的变量具有明确的位地址,这意味着程序员可以直接通过地址来访问或修改这些变量的状态。sbit类型常用于访问单片机中那些具有特定功能的寄存器位,如I\/O端口的状态、定时器的控制位等。由于sbit变量是可寻址的,因此它们提供了更高的灵活性和控制精度。举例来说,在C51程序中,我们...

相似回答