Keil C语言
相信读者们对标准C语言(ANSI C)已经十分熟悉。Keil中的C语言与ANSI C语言略有
变化,下面对Keil C语言的介绍将着重介绍Keil C与ANSI C不同的地方。
数据类型
表3.1中列出了Keil uVision2 C51编译器所支持的数据类型。在标准C语言中基本的数
据类型为char、 int、 short、 long、 float和double, 而在C51编译器中int和short相同, float
和double相同,这里就不列出说明了。下面来看看它们的具体定义:

char 字符类型
char类型的长度是一个字节, 通常用于定义处理字符数据的变量或常量。 分无符号字符
类型unsigned char和有符号字符类型signed char,默认值为signed char类型。unsigned
char类型用字节中所有的位来表示数值,所可以表达的数值范围是0~255。signed char类
型用字节中最高位字节表示数据的符号,“0”表示正数,“1”表示负数,负数用补码表示
(正数的补码与原码相同,负二进制数的补码等于它的绝对值按位取反后加1)。所能表示
的数值范围是-128~+127。unsigned char常用于处理ASCII字符或用于处理小于或等于255的整型数。在51单片机程序中,
nt 整型
int整型长度为两个字节,用于存放一个双字节数据。分有符号int整型数signed int
和无符号整型数unsigned int,默认值为signed int类型。signed int表示的数值范围是
-32768~+32767,字节中最高位表示数据的符号, “0”表示正数, “1”表示负数。unsigned
int表示的数值范围是0~65535。
long 长整型
long长整型长度为四个字节,用于存放一个四字节数据。分有符号long长整型signed
long和无符号长整型unsigned long,默认值为signed long类型。signed int表示的数值范
围是-2147483648~+2147483647,字节中最高位表示数据的符号,“0”表示正数,“1”表
示负数。unsigned long表示的数值范围是0~4294967295。
float 浮点型
float浮点型在十进制中具有7位有效数字,是符合IEEE-754标准的单精度浮点型数据,
占用四个字节。
* 指针型
指针型本身就是一个变量, 在这个变量中存放的指向另一个数据的地址。 这个指针变量
要占据一定的内存单元,对不同的处理器长度也不尽相同,在C51中它的长度一般为1~3个
字节。
bit 位标量
bit位标量是C51编译器的一种扩充数据类型,利用它可定义一个位标量,但不能定义
位指针,也不能定义位数组不能定义位指针,也不能定义位数组。它的值是一个二进制位,不是0就是1,类似一些高级语言中Boolean类型中的True和False。
sfr 特殊功能寄存器
sfr也是一种扩充数据类型,占用一个内存单元,值域为0~255。利用它可以访问51单
片机内部的所有特殊功能寄存器利用它可以访问51单片机内部的所有特殊功能寄存器。如用sfr P1 = 0x90 这一句定P1为P1端口在片内的寄存器,在后面的语句中我们用P1 = 255(对P1 端口的所有引脚置高电平)之类的语句来操作特殊功能寄存器。
sfr16 16 位特殊功能寄存器
sfr16占用两个内存单元, 值域为0~65535。 sfr16和sfr一样用于操作特殊功能寄存器,
所不同的是它用于操作占两个字节的寄存器,如定时器T0和T1。
sbit 可寻址位
sbit同样是C51中的一种扩充数据类型,利用它可以访问芯片内部RAM中的可寻址位或
特殊功能寄存器中的可寻址位。如先前我们定义了
sfr P1 = 0x90; //因P1 端口的寄存器是可位寻址的,所以我们可以定义
sbit P1_1 = P1^1; //P1_1 为P1 中的P1.1 引脚
同样我们可以用P1.1的地址去写,如sbit P1_1 = 0x91;
这样我们在以后的程序语句中就可以用P1_1来对P1.1引脚进行读写操作了。 通常这些可
以直接使用系统提供的预处理文件, 里面已定义好各特殊功能寄存器的简单名字, 直接引用
可以省去一点时间。当然你也可以自己写自己的定义文件,用你认为好记的名字。
举报/反馈