单片机原理及应用C语言版4.ppt

上传人:豆**** 文档编号:59099503 上传时间:2022-11-09 格式:PPT 页数:174 大小:1.51MB
返回 下载 相关 举报
单片机原理及应用C语言版4.ppt_第1页
第1页 / 共174页
单片机原理及应用C语言版4.ppt_第2页
第2页 / 共174页
点击查看更多>>
资源描述

《单片机原理及应用C语言版4.ppt》由会员分享,可在线阅读,更多相关《单片机原理及应用C语言版4.ppt(174页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、单片机原理及应用C语言版4 Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望第第4章章 单片机单片机C语言及程序设计语言及程序设计4.1 C51概述概述4.2 C51数据类型及存储数据类型及存储4.3 C51变量的定义及数变量的定义及数据存储区域据存储区域4.4 C51位变量的定义位变量的定义4.5 C51特殊功能寄存器特殊功能寄存器的定义的定义4.6 C51指令的定义指令的定义4.7 C51的输入的输入/输输出出4.8 C51函数的定义函数的定义4.9 C51与汇

2、编语言与汇编语言混合编程混合编程4.10 C51集成开发集成开发软件软件Keil C目目 录录第第4章章 单片机单片机C语言及程序设计语言及程序设计本章主要讨论本章主要讨论C51变量的定义和函数的定变量的定义和函数的定义,以及义,以及Keil C软件的使用等。软件的使用等。本章内容的安排,认为读者已经学习过本章内容的安排,认为读者已经学习过C语言,具有语言,具有C语言的基本知识,因此,本章语言的基本知识,因此,本章内容完全是结合单片机来讲解,也就是补充内容完全是结合单片机来讲解,也就是补充C语言在单片机方面的概念、数据定义和函语言在单片机方面的概念、数据定义和函数定义等。数定义等。通过本章学习

3、,使读者能够比较顺利地通过本章学习,使读者能够比较顺利地编写编写C51程序。程序。4.1 C51概述概述主要内容主要内容4.1.1 C语言编程的优势语言编程的优势4.1.2 C51与与ANSI C的区别的区别4.1.3 C51扩展的关键字扩展的关键字4.1 C51概述概述学习单片机学习单片机C语言的必要性语言的必要性随着单片机性能的不断提高,随着单片机性能的不断提高,C语言编译语言编译调试工具的不断完善,以及现在对单片机产调试工具的不断完善,以及现在对单片机产品辅助功能的要求、对开发周期不断缩短的品辅助功能的要求、对开发周期不断缩短的要求,使得要求,使得越来越多的单片机编程人员转向越来越多的单

4、片机编程人员转向使用使用C语言语言,因此有必要在单片机课程中讲,因此有必要在单片机课程中讲授授“单片机单片机C语言语言”。“C51”概念:概念:为了与为了与ANSI C区别,区别,把把“单片机单片机C语言语言”称为称为“C51”,也称为,也称为“Keil C”。4.1.1 C语言编程的优势语言编程的优势在编程方面,使用在编程方面,使用C51较汇编语言有诸多较汇编语言有诸多优势:优势:1)编程容易)编程容易 2)容易实现复杂的数值计算)容易实现复杂的数值计算3)容易阅读与交流)容易阅读与交流4)容易调试与维护程序)容易调试与维护程序5)容易实现模块化开发)容易实现模块化开发 6)程序可移植性好)

5、程序可移植性好 4.1.2 C语言与语言与ANSI 的区别的区别用汇编语言编写单片机程序时,必须要用汇编语言编写单片机程序时,必须要考虑其存储器的结构考虑其存储器的结构,尤其要考虑其片内数,尤其要考虑其片内数据存储器、特殊功能寄存器是否正确合理的据存储器、特殊功能寄存器是否正确合理的使用,以及按照实际地址端口数据的处理。使用,以及按照实际地址端口数据的处理。用用C51编写程序,虽然不像汇编语言那样编写程序,虽然不像汇编语言那样需要具体地组织、分配存储器资源,但是需要具体地组织、分配存储器资源,但是C51对数据类型和变量的定义,必须要与单对数据类型和变量的定义,必须要与单片机的存储结构相关联片机

6、的存储结构相关联,否则编译器不能正,否则编译器不能正确地映射定位。确地映射定位。4.1.2 C语言与语言与ANSI 的区别的区别用用C51编写单片机程序,与用编写单片机程序,与用ANSI C编编写程序的写程序的不同之处是不同之处是,需要根据单片机存储需要根据单片机存储器结构及内部资源,定义相应的数据类型和器结构及内部资源,定义相应的数据类型和变量变量。其它的语法规定、程序结构及程序设计其它的语法规定、程序结构及程序设计方法,都与方法,都与ANSI C相同。所以相同。所以本章主要介本章主要介绍绍C51各种变量的定义、指针定义、函数定各种变量的定义、指针定义、函数定义和混合编程义和混合编程。4.1

7、.3 C51扩展的关键字扩展的关键字由于单片机在结构及编程上的特殊要求,由于单片机在结构及编程上的特殊要求,C51有自己的特殊关键字,称之为有自己的特殊关键字,称之为C51扩展扩展的关键字的关键字,下面给出常用的,下面给出常用的C51扩展的关键扩展的关键字。字。_at_bdatabit codedataidata interruptpdatareentrant sbitsfrsfr16usingvolatilexdata这些关键字在后面会陆续接触到,此处这些关键字在后面会陆续接触到,此处先不给出它们的含义。先不给出它们的含义。4.2 C51数据类型及存储数据类型及存储主要内容主要内容4.2.1

8、 C51的数据类型的数据类型4.2.2 C51数据的存储数据的存储4.2.1 C51的数据类型的数据类型表表4-1 C51数据类型、长度和数值范围数据类型、长度和数值范围数据类型数据类型表示方法表示方法长长 度度数数 值值 范范 围围无符号字符型无符号字符型 unsigned char 1字节字节 0255有符号字符型有符号字符型 signed char1字节字节-128127无符号整型无符号整型unsigned int2字节字节 065535有符号整型有符号整型signed int2字节字节-3276832767无符号长整型无符号长整型 unsigned long 4字节字节 0429496

9、7295有符号长整型有符号长整型 signed long4字节字节-21474836482147483647浮点型浮点型float4字节字节 1.1755E-383.40E+38特殊功能寄特殊功能寄存器型存器型sfrsfr161字节字节2字节字节0255065535位类型位类型bit、sbit1位位0或或14.2.1 C51的数据类型的数据类型数据类型转换数据类型转换1)自动转换)自动转换转换规则是向高精度数据类型转换、向转换规则是向高精度数据类型转换、向有符号数据类型转换有符号数据类型转换。如字符型变量与整型。如字符型变量与整型变量相加时,则位变量先转换字符型或整型变量相加时,则位变量先转换

10、字符型或整型数据,然后相加。数据,然后相加。2)强制转换)强制转换像像ANSI C一样,一样,通过强制类型转换的方通过强制类型转换的方式进行转换式进行转换。如:。如:unsignedintb;floatc;b=(int)c;4.2.2 C51数据的存储数据的存储MCS-51单片机只有单片机只有bit和和unsigned char两两种数据类型支持机器指令种数据类型支持机器指令,而其它类型的数,而其它类型的数据都需要转换成据都需要转换成bit或或unsigned char型进行存型进行存储。储。为了减少单片机的存储空间和提高运行为了减少单片机的存储空间和提高运行速度,要尽可能地使用速度,要尽可能

11、地使用unsigned char型数据。型数据。一、位变量的存储一、位变量的存储bit和和sbit型位变量,直接存于型位变量,直接存于RAM的位的位寻址空间,包括低寻址空间,包括低128位和特殊功能寄存器位和特殊功能寄存器位。位。4.2.2 C51数据的存储数据的存储二、字符变量的存储二、字符变量的存储字符变量字符变量(char):无论是无论是unsigned char数据还是数据还是signed char数据,均为数据,均为1个字个字节,能够被直接存储在节,能够被直接存储在RAM中,可以存储中,可以存储在在00 x7f区域,也可以存储在区域,也可以存储在0 x800 xff区区域,与变量的定

12、义有关。域,与变量的定义有关。unsigned char数:数:可直接被可直接被MSC-51接受接受signed char数据:数据:用补码表示。用补码表示。需要额外需要额外的操作的操作来测试、处理符号位,使用的是两种来测试、处理符号位,使用的是两种库函数,代码量大,运算速度降低。库函数,代码量大,运算速度降低。4.2.2 C51数据的存储数据的存储三、整型变量的存储三、整型变量的存储整型变量整型变量(int):不管是不管是unsigned int数据还是数据还是signed int数据,均为数据,均为2个字节,其个字节,其存存储方法是高位字节保存在低地储方法是高位字节保存在低地址址(在前面)

13、,(在前面),低位字节保存低位字节保存在高地址在高地址(在后面)(在后面)。例如,例如,整型变量的值为整型变量的值为0 x1234,在内存,在内存中的存放如右图所示。中的存放如右图所示。signed int数据用补码表示。数据用补码表示。地址地址低低高高:1234:4.2.2 C51数据的存储数据的存储四、长整型变量的存储四、长整型变量的存储长整型变量(长整型变量(long)为)为4个个字节,其存储方法与整型数据字节,其存储方法与整型数据一样,是一样,是最高位字节保存的地最高位字节保存的地址最低址最低(在最前面),(在最前面),最低位最低位字节保存的地址最高字节保存的地址最高(在最后(在最后面

14、)。面)。如长整型变量的值为如长整型变量的值为0 x12345678,在内,在内存中的存放方法如右图所示。不管是存中的存放方法如右图所示。不管是unsigned long数据还是数据还是signed long数据。数据。地址地址低低高高:12345678:4.2.2 C51数据的存储数据的存储五、浮点型变量的存储五、浮点型变量的存储浮点型变量浮点型变量(fload)占)占4个字节,个字节,用指数用指数方式表示方式表示,其具体格式与编译器有关。,其具体格式与编译器有关。对于对于Keil C,采用的是,采用的是IEEE-754标准标准,具有具有24位精度,尾数的最高位始终为位精度,尾数的最高位始终

15、为1,因,因而不保存。而不保存。具体分布为:具体分布为:1位符号位,位符号位,8位阶位阶码位,码位,23位尾数,如下图所示。位尾数,如下图所示。字节地址字节地址0123浮点数浮点数内容内容SEEEEEEEEMMMMMMMMMMMMMMMMMMMMMMM符号和阶码符号和阶码 尾数高位尾数高位尾数低位尾数低位4.2.2 C51数据的存储数据的存储符号位符号位S:1表示负数,表示负数,0表示正数。表示正数。阶码:阶码:用移码表示。如,实际阶码用移码表示。如,实际阶码-126用用1表示,实际阶码表示,实际阶码0用用127表示,表示,即实际阶即实际阶码数加上码数加上127得到阶码的表达数得到阶码的表达数

16、。阶码数值范围:阶码数值范围:-126+128。4.2.2 C51数据的存储数据的存储例如浮点数例如浮点数-12.5符号位为符号位为1,12.5的二进制数为的二进制数为1100.1=1.1001E+0011,阶码数值为阶码数值为3+127=130=10000010B,尾数为尾数为1001。因此,其十六进制数为因此,其十六进制数为0 xC1480000,则存储结构,则存储结构如右图所示。如右图所示。地址地址低低高高:C1480000:说明:说明:教材中存储结构是错的。教材中存储结构是错的。4.3 C51变量的定义及数据存储区域变量的定义及数据存储区域主要内容主要内容4.3.1 C51变量的定义变

17、量的定义4.3.2 C51变量的存储类型变量的存储类型4.3.3 C51变量的存储区域变量的存储区域4.3.4 C51变量定义举例变量定义举例4.3.5 C51变量的存储模式变量的存储模式4.3.6 C51变量的绝对定位变量的绝对定位4.3.1 C51变量的定义变量的定义C51变量定义的一般格式为:变量定义的一般格式为:存储类型存储类型数据类型数据类型 存储区存储区变量名变量名1=初值初值,变量名变量名2=初值初值,或或存储类型存储类型存储区存储区 数据类型数据类型 变量名变量名1=初值初值,变量名变量名2=初值初值,可见变量可见变量(非位变量)(非位变量)的定义由的定义由4部分组部分组成成,

18、即在变量定义时,指定变量,即在变量定义时,指定变量4种属性。种属性。数据类型:数据类型:在前面的在前面的4.2中已经叙述过,中已经叙述过,对于变量名也无须多说,对于变量名也无须多说,下面主要解释下面主要解释“存存储类型储类型”和和“存储区存储区”等概念等概念。4.3.2 C51变量的存储类型变量的存储类型存储类型这个属性我们仍沿用存储类型这个属性我们仍沿用ANSI C的的说法说法,尽量不改变原来的含义。,尽量不改变原来的含义。按照按照ANSI C,C语言的变量有语言的变量有4种存储类种存储类型型:动态存储(动态存储(auto)静态存储(静态存储(static)全局存储(全局存储(extern)

19、寄存器存储(寄存器存储(register)4.3.2 C51变量的存储类型变量的存储类型一、动态存储一、动态存储动态(存储)变量:动态(存储)变量:用用auto定义的为动态定义的为动态变量,也叫自动变量变量,也叫自动变量。作用范围:作用范围:在定义它的函数内或复合语在定义它的函数内或复合语句内部。句内部。当定义它的函数或复合语当定义它的函数或复合语句执行时,句执行时,C51才为变量分配存储空间,结才为变量分配存储空间,结束时所占用的存储空间释放。束时所占用的存储空间释放。定义变量时,定义变量时,auto可以省略可以省略,或者说如果,或者说如果省略了存储类型项,则认为是动态变量。省略了存储类型项

20、,则认为是动态变量。动动态变量一般分配使用寄存器或堆栈态变量一般分配使用寄存器或堆栈。4.3.2 C51变量的存储类型变量的存储类型二、静态存储二、静态存储静态(存储)变量:静态(存储)变量:用用static定义的为静定义的为静态变量态变量。分为内部静态和外部静态变量。分为内部静态和外部静态变量。内部静态变量:内部静态变量:在函数体内定义的为内在函数体内定义的为内部静态变量部静态变量。在函数内可以任意使用和在函数内可以任意使用和修改,函数运行结束后会一直存在,但在函修改,函数运行结束后会一直存在,但在函数外不可见,即在函数体外得到保护。数外不可见,即在函数体外得到保护。外部静态变量:外部静态变

21、量:在函数体外部定义的为在函数体外部定义的为外部静态变量外部静态变量。在定义的文件内可以任意使。在定义的文件内可以任意使用和修改,外部静态变量会一直存在,但在用和修改,外部静态变量会一直存在,但在文件外不可见,即在文件外得到保护。文件外不可见,即在文件外得到保护。4.3.2 C51变量的存储类型变量的存储类型三、外部存储三、外部存储外部(存储)变量:外部(存储)变量:用用extern声明声明的变量的变量为外部变量为外部变量,是在其它文件定义过的全局变,是在其它文件定义过的全局变量。量。用用extern声明后,便可以在所声明声明后,便可以在所声明的文件中使用。的文件中使用。需要注意的是:需要注意

22、的是:在定义变量时,即便是在定义变量时,即便是全局变量,也不能使用全局变量,也不能使用extern定义定义。4.3.2 C51变量的存储类型变量的存储类型四、寄存器存储四、寄存器存储寄存器(存储)变量:寄存器(存储)变量:用用register定义的定义的变量为寄存器变量变量为寄存器变量。寄存器变量存放在寄存器变量存放在CPU的寄存器中的寄存器中,这,这种变量处理速度快,但数目少。种变量处理速度快,但数目少。C51中的寄存器变量:中的寄存器变量:C51的编译器在编的编译器在编译时,能够自动识别程序中使用译时,能够自动识别程序中使用频率高的变频率高的变量量,并将其,并将其安排为寄存器变量安排为寄存

23、器变量,用户不用专,用户不用专门声明。门声明。4.3.3 C51变量的存储区域变量的存储区域变量的存储区属性是单片机扩展的概念变量的存储区属性是单片机扩展的概念,非常重要,非常重要,它涉及到它涉及到7个新的关键字个新的关键字。MCS-51单片机有四个存储空间单片机有四个存储空间,分成三,分成三类,它们是片内数据存储空间、片外数据存类,它们是片内数据存储空间、片外数据存储空间和程序存储空间。储空间和程序存储空间。MCS-51单片机有更多的存储区域:单片机有更多的存储区域:由于由于片内数据存储器和片外数据存储器又分成不片内数据存储器和片外数据存储器又分成不同的区域,所以同的区域,所以单片机的变量有

24、更多的存储单片机的变量有更多的存储区域区域。在定义变量时,必须明确指出在定义变量时,必须明确指出是存放在哪个区域是存放在哪个区域。4.3.3 C51变量的存储区域变量的存储区域表表4-2 C51存储区与存储空间的对应关系存储区与存储空间的对应关系关键字关键字对应的存储空间及范围对应的存储空间及范围codeROM空间,空间,64KB全空间全空间data片内片内RAM,直接寻址,低,直接寻址,低128字节字节bdata片内片内RAM,位寻址区,位寻址区0 x200 x2f,可字节访问,可字节访问idata 片内片内RAM,间接寻址,间接寻址,256字节,与字节,与 Ri 对应对应pdata片外片外

25、RAM,分页寻址的,分页寻址的256字节字节(P2不变不变),P2改变可寻址改变可寻址64KB全空间,与全空间,与MOVX Ri 对应对应xdata片外片外RAM,64KB全空间全空间bit片内片内RAM位寻找区位寻找区,位地址位地址0 x000 x7f,128位位4.3.4 C51变量定义举例变量定义举例1)定义存储在)定义存储在data区域区域的的动态动态unsigned char变量:变量:unsigned char data sec=0,min=0,hou=0;2)定义存储在)定义存储在data区域区域的的静态静态unsigned char变量:变量:static unsigned c

26、har data scan_code=0 xfe;3)定义存储在)定义存储在data区域区域的的静态静态unsigned int变量:变量:static unsigned int data dd;4.3.4 C51变量定义举例变量定义举例4)定义存储在)定义存储在bdata区域区域的的动态动态unsigned char变量:变量:unsigned char bdata operate,operate1;/定义指示操作的可位寻址的变量定义指示操作的可位寻址的变量5)定义存储在)定义存储在idata区域区域的的动态动态unsigned char数组:数组:unsigned char idata t

27、emp20;6)定义在)定义在pdata区域区域的的动态动态有符号有符号int数数组:组:int pdata send_data30;/定义存放发送数据的数组定义存放发送数据的数组 4.3.4 C51变量定义举例变量定义举例7)定义存储在)定义存储在xdata区域区域的的动态动态unsigned int数组:数组:unsigned int xdata receiv_buf50;/定义存放接受数据的数组定义存放接受数据的数组8)定义存储在)定义存储在code区域区域的的unsigned char数组:数组:unsigned char code dis_code10=0 x3f,0 x06,0 x

28、5b,0 x4f,0 x66,0 x6d,0 x7d,0 x07,0 x7f,0 x6f;/定义共阴极数码管段码数组定义共阴极数码管段码数组4.3.5 C51变量的存储模式变量的存储模式存储模式:存储模式:如果在定义变量时缺省了存储如果在定义变量时缺省了存储区属性,则编译器会自动选择默认的存储区区属性,则编译器会自动选择默认的存储区域,域,也就是存储模式也就是存储模式。变量的存储模式也就是程序(或函数)的变量的存储模式也就是程序(或函数)的编译模式编译模式。编译模式分为三种:编译模式分为三种:小模式(小模式(small)、)、紧凑模式(紧凑模式(compact)和大模式()和大模式(large

29、)。)。编译模式由编译控制命令决定。编译模式由编译控制命令决定。存储模式(编译模式)决定了变量的默认存储模式(编译模式)决定了变量的默认存储区域和参数的传递方法存储区域和参数的传递方法。4.3.5 C51变量的存储模式变量的存储模式一、一、small模式模式在在small模式下,变量的默认存储区域是模式下,变量的默认存储区域是“data”、“idata”,即未指出存储区域,即未指出存储区域的变量保存到片内数据存储器中,并且的变量保存到片内数据存储器中,并且堆栈堆栈也安排在该区域中也安排在该区域中。small模式的特点:模式的特点:存储容量小,但速度存储容量小,但速度快。快。在在small模式下

30、参数的传递:模式下参数的传递:通过寄存器、通过寄存器、堆栈或片内数据存储区完成的。堆栈或片内数据存储区完成的。4.3.5 C51变量的存储模式变量的存储模式二、二、compact模式模式在在compact模式下,变量的默认存储区域模式下,变量的默认存储区域是是“pdata”,即未指出存储区域的变量保,即未指出存储区域的变量保存到片外数据存储器的一页中,最大变量数存到片外数据存储器的一页中,最大变量数为为256字节,并且字节,并且堆栈也安排在该区域中堆栈也安排在该区域中。compact模式的其特点:模式的其特点:是存储容量较是存储容量较small模式大,速度较模式大,速度较small模式稍慢,但

31、比模式稍慢,但比large模式要快。模式要快。在在compact模式下参数的传递:模式下参数的传递:通过片外通过片外数据区的一个固定页完成的。数据区的一个固定页完成的。4.3.5 C51变量的存储模式变量的存储模式三、三、large模式模式在在large模式下,变量的默认存储区域是模式下,变量的默认存储区域是“xdata”,即未指出存储区域的变量保存,即未指出存储区域的变量保存到片外数据存储器,最大变量数可达到片外数据存储器,最大变量数可达64KB,并且,并且堆栈也安排在该区域中堆栈也安排在该区域中。large模式的特点:模式的特点:存储容量大,速度慢存储容量大,速度慢large模式下参数的传

32、递方式:模式下参数的传递方式:参数的传参数的传递也是通过片外数据存储器完成的。递也是通过片外数据存储器完成的。4.3.5 C51变量的存储模式变量的存储模式C51支持混合模式:支持混合模式:即可以对函数设置编即可以对函数设置编译模式,所以在译模式,所以在large模式下,可以对某些函模式下,可以对某些函数设置为数设置为compact模式或模式或small模式,从而提模式,从而提高运行速度。高运行速度。默认编译模式:默认编译模式:如果文件或函数未指明编如果文件或函数未指明编译模式,则编译器按译模式,则编译器按small模式处理模式处理。编译模式控制命令:编译模式控制命令:“#pragma sma

33、ll(或或compact、large)”应放在文件的开始。应放在文件的开始。4.3.6 C51变量的绝对定位变量的绝对定位C51有三种方式可以对变量有三种方式可以对变量(I/O端口)端口)绝对定位:绝对定位:绝对定位关键字绝对定位关键字_at_、指针、库、指针、库函数的绝对定位宏。函数的绝对定位宏。对于后两种方式,在对于后两种方式,在后面指针一节介绍。后面指针一节介绍。C51扩展的关键字扩展的关键字_at_专门用于对变量作专门用于对变量作绝对定位绝对定位,_at_使用在变量的定义中,其格使用在变量的定义中,其格式为:式为:存储类型存储类型 数据类型数据类型 存储区存储区 变量名变量名1 _at

34、_ 地址常数地址常数,变量名,变量名2 4.3.6 C51变量的绝对定位变量的绝对定位举例说明举例说明_at_的使用方法的使用方法1)对)对data区域区域中的中的 unsigned char变量变量aa作绝对定位:作绝对定位:unsigned char data aa _at_ 0 x30;2)对)对pdata区域区域中的中的 unsigned int数组数组cc作绝对定位:作绝对定位:unsigned int pdata cc10 _at_ 0 x34;3)对)对xdata区域区域中的中的 unsigned char变量变量printer_port作绝对定位:作绝对定位:unsigned

35、char xdata printer_port _at_ 0 x7fff;4.3.6 C51变量的绝对定位变量的绝对定位对变量绝对定位的几点说明:对变量绝对定位的几点说明:1)绝对地址变量)绝对地址变量在定义时不能初始化在定义时不能初始化,因此不能对因此不能对code型变量绝对定位;型变量绝对定位;2)绝对地址变量)绝对地址变量只能够是全局变量只能够是全局变量,不,不能在函数中对变量绝对定位;能在函数中对变量绝对定位;3)绝对地址变量)绝对地址变量多用于多用于I/O端口端口,一般情,一般情况下不对变量作绝对定位;况下不对变量作绝对定位;3)位变量不能使用)位变量不能使用_at_绝对定位。绝对定

36、位。4.4 C51位变量的定义位变量的定义主要内容主要内容4.4.1 bit型位变量的定义型位变量的定义4.4.2 sbit型位变量的定义型位变量的定义4.4.1 bit型位变量的定义型位变量的定义常说的位变量指的就是常说的位变量指的就是bit型位变量型位变量。C51的的bit型位变量定义的一般格式为:型位变量定义的一般格式为:存储类型存储类型 bit 位变量名位变量名1=初值初值,位变量名,位变量名2=初值初值,bit位变量被保存在位变量被保存在RAM中的位寻址区中的位寻址区域域(字节地址为(字节地址为0 x200 x2f,16字节)。字节)。例如:例如:bitflag_run,receiv

37、_bit=0;static bit send_bit;4.4.1 bit型位变量的定义型位变量的定义两点说明:两点说明:1)bit型位变量与其它变量一样,型位变量与其它变量一样,可以可以作为函数的形参作为函数的形参,也可以作为,也可以作为函数的返回函数的返回值值,即函数的类型可以是位型的;,即函数的类型可以是位型的;2)位变量)位变量不能定义指针不能定义指针,不能定义数不能定义数组组。4.4.2 sbit型位变量的定义型位变量的定义对于能够按位寻址的特殊功能寄存器、对于能够按位寻址的特殊功能寄存器、定义在位寻址区域的变量(字节型、整型、定义在位寻址区域的变量(字节型、整型、长整型),可以对其各

38、位用长整型),可以对其各位用sbit定义位变量。定义位变量。为了方便起见,分开讨论为了方便起见,分开讨论按位寻址的特按位寻址的特殊功能寄存器中位变量的定义、按位寻址殊功能寄存器中位变量的定义、按位寻址的变量中位变量的定义。的变量中位变量的定义。4.4.2 sbit型位变量的定义型位变量的定义一、特殊功能寄存器中位变量定义一、特殊功能寄存器中位变量定义能够按位寻址的能够按位寻址的特殊功能寄存器中位变特殊功能寄存器中位变量定义的一般格式为:量定义的一般格式为:sbit 位变量名位变量名 位地址表达式位地址表达式这里的位地址表达式有三种形式:这里的位地址表达式有三种形式:直接位地址直接位地址特殊功能

39、寄存器名带位号特殊功能寄存器名带位号字节地址带位号字节地址带位号4.4.2 sbit型位变量的定义型位变量的定义1、用直接位地址定义位变量、用直接位地址定义位变量这种情况下位变量的定义格式为:这种情况下位变量的定义格式为:sbit 位变量名位变量名 位地址常数位地址常数这里的位地址常数范围为这里的位地址常数范围为0 x800 xff,实际是定义特殊功能寄存器的位实际是定义特殊功能寄存器的位。例如:。例如:sbitP0_0=0 x80;sbitP1_1=0 x91;sbitRS0=0 xd3;/定义定义PSW的第的第3位位sbitET0=0 xa9;/定义定义IE的第的第1位位 4.4.2 sb

40、it型位变量的定义型位变量的定义2、特殊功能寄存器名带位号定义、特殊功能寄存器名带位号定义这时位变量的定义格式为:这时位变量的定义格式为:sbit 位变量名位变量名 特殊功能寄存器名特殊功能寄存器名 位号常数位号常数这里的位号常数为这里的位号常数为07。例如:。例如:sbitP0_3=P0 3;sbitP1_4=P1 4;sbitOV=PSW 2;/定义定义PSW的第的第2位位sbitES=IE 4;/定义定义IE的第的第4位位 4.4.2 sbit型位变量的定义型位变量的定义3、寄存器地址带位号定义位变量、寄存器地址带位号定义位变量在这种情况下位变量的定义格式为:在这种情况下位变量的定义格式

41、为:sbit 位变量名位变量名 特殊功能寄存器地址特殊功能寄存器地址 位号常数位号常数这里的位号常数同上,为这里的位号常数同上,为07。例如:。例如:sbitP0_6=0 x80 6;sbitP1_7=0 x90 7;sbitAC=0 xd0 6;/定义定义PSW的第的第6位位sbitEA=0 xa8 7;/定义定义IE的第的第7位位 4.4.2 sbit型位变量的定义型位变量的定义4、几点说明、几点说明1)用)用sbit定义的位变量,必须能够按位操作,定义的位变量,必须能够按位操作,而不能够对无位操作功能的位定义位变量。而不能够对无位操作功能的位定义位变量。2)用)用sbit定义位变量,必须

42、放在函数外面作为定义位变量,必须放在函数外面作为全局位变量,而不能在函数内部定义。全局位变量,而不能在函数内部定义。3)用)用sbit每次只能定义一个位变量。每次只能定义一个位变量。4)对其它模块定义的位变量()对其它模块定义的位变量(bit型或型或 sbit型)型)的引用声明,都使用的引用声明,都使用bit。5)用)用sbit定义的是一种绝对定位的位变量(因定义的是一种绝对定位的位变量(因为名字是与确定位地址对应的),具有特定的意为名字是与确定位地址对应的),具有特定的意义,在应用时不能像义,在应用时不能像bit型位变量那样随便使用。型位变量那样随便使用。4.4.2 sbit型位变量的定义型

43、位变量的定义二、二、位寻址区变量的位寻址区变量的位定义位定义对对bdata型变量(字节型、整型、长整型)型变量(字节型、整型、长整型),被保存在,被保存在RAM中的位寻址区,因此中的位寻址区,因此可以可以对对bdata型变量各位作位变量定义型变量各位作位变量定义。这样,既可以对这样,既可以对bdata型变量作字节(或型变量作字节(或整型、长整型)操作,也可以作位操作。整型、长整型)操作,也可以作位操作。bdata型变量的位定义格式:型变量的位定义格式:sbit 位变量名位变量名 bdata型变量名型变量名 位号常数位号常数 4.4.2 sbit型位变量的定义型位变量的定义bdata型变量为在此

44、之前应该是定义过的型变量为在此之前应该是定义过的,位号常数可以是位号常数可以是07(8位字节变量),或位字节变量),或015(16位整型变量),或位整型变量),或031(32位字位字长整型变量)。例如:长整型变量)。例如:unsigned char bdataoperate;对对operate的低的低4位作位变量定义:位作位变量定义:sbit flag_key=operate 0;/键盘标志位键盘标志位sbit flag_dis=operate 1;/显示标志位显示标志位sbit flag_mus=operate 2;/音乐标志位音乐标志位sbit flag_run=operate 3;/运行

45、标志位运行标志位 4.5 C51特殊功能寄存器的定义特殊功能寄存器的定义主要内容主要内容4.5.1 8位特殊功能寄存器的定义位特殊功能寄存器的定义4.5.2 16位特殊功能寄存器的定义位特殊功能寄存器的定义4.5.1 8位特殊功能寄存器的定义位特殊功能寄存器的定义定义的一般格式为:定义的一般格式为:sfr特殊功能寄存器名特殊功能寄存器名 地址常数地址常数地址常数范围:地址常数范围:0 x800 xff。特殊功能寄存器定义例子(见特殊功能寄存器定义例子(见reg51.h、reg52.h等文件):等文件):sfrP0=0 x80;/定义定义P0寄存器寄存器sfrP1=0 x90;/定义定义P1口寄

46、存器口寄存器sfrPSW=0 xd0;/定义定义PSWsfrIE=0 xa8;/定义定义IE 4.5.2 16位特殊功能寄存器的定义位特殊功能寄存器的定义定义的一般格式为:定义的一般格式为:sfr16 特殊功能寄存器名特殊功能寄存器名 地址常数地址常数地址常数范围:地址常数范围:0 x800 xff。例如(见例如(见reg51.h、reg52.h等文件):等文件):sfr16 DPTR=0 x82;sfr16 T2=0 xcc;/含含TL2和和TH2sfr16 RCAP2=0 xca;/含含RCAP2L/和和RCAP2H,0 xca为为RCAP2L的地址的地址4.5.2 16位特殊功能寄存器的

47、定义位特殊功能寄存器的定义几点说明:几点说明:1)定义特殊功能寄存器中的地址必须)定义特殊功能寄存器中的地址必须在在0 x800 xff范围内。范围内。2)定义特殊功能寄存器,必须放在函)定义特殊功能寄存器,必须放在函数外面作为全局变量。数外面作为全局变量。3)用)用sfr或或sfr16每次只能定义一个特殊每次只能定义一个特殊功能寄存器。功能寄存器。4)像)像sbit一样,用一样,用sfr或或sfr16定义的是绝定义的是绝对定位的变量(因为名字是与确定地址对对定位的变量(因为名字是与确定地址对应的),具有特定的意义,在应用时不能应的),具有特定的意义,在应用时不能像一般变量那样随便使用。像一般

48、变量那样随便使用。4.6 C51指针的定义指针的定义主要内容主要内容4.6.1 通用指针通用指针4.6.2 存储器专用指针存储器专用指针4.6.3 指针变换指针变换4.6.4 C51指针应用指针应用4.6 C51指针的定义指针的定义由于由于MCS-51单片机有三种不同类型的存单片机有三种不同类型的存储空间,并且还有不同的存储区域,储空间,并且还有不同的存储区域,因此因此C51指针的内容更丰富。指针的内容更丰富。指针除了具有像变量的四种属性(存储指针除了具有像变量的四种属性(存储类型、数据类型、存储区、变量名)外,类型、数据类型、存储区、变量名)外,按按存储区,将指针分为通用指针和不同存储区存储

49、区,将指针分为通用指针和不同存储区域的专用指针。域的专用指针。4.6.1 通用指针通用指针所谓通用指针,就是通过该类指针可以所谓通用指针,就是通过该类指针可以访问所有的存储空间访问所有的存储空间。在在C51库函数中通常使用这种指针来访库函数中通常使用这种指针来访问。问。通用指针用通用指针用3个字节来表示:个字节来表示:第一个字节:表示指针第一个字节:表示指针所指向的存储空间所指向的存储空间第二个字节:为指针第二个字节:为指针地址的高字节地址的高字节第三个字节:为指针第三个字节:为指针地址的低字节地址的低字节4.6.1 通用指针通用指针通用指针的定义与一般通用指针的定义与一般C语言指针的定语言指

50、针的定义相同,其格式为:义相同,其格式为:存储类型存储类型 数据类型数据类型 *指针名指针名1,*指针名指针名2,例如:例如:unsigned char *cpt;int *dpt;long *lpt;static char *ccpt;通用指针的特点:通用指针的特点:定义简单定义简单访问所有空间访问所有空间访问速度慢访问速度慢 4.6.2 存储器专用指针存储器专用指针所谓存储器专用指针,就是通过该类指所谓存储器专用指针,就是通过该类指针,只能够访问规定的存储空间区域针,只能够访问规定的存储空间区域。指针本身占用指针本身占用1个字节(个字节(data*,idata*,bdata*,pdata*

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 小学资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁