单片机ppt课件单片机的C语言编程.ppt
《单片机ppt课件单片机的C语言编程.ppt》由会员分享,可在线阅读,更多相关《单片机ppt课件单片机的C语言编程.ppt(92页珍藏版)》请在三一办公上搜索。
1、第10章 单片机的C语言编程,单片机原理、接口及应用,内 容 提 要, C51程序结构 C51的数据类型 数据的存贮类型和存贮模式 C51对SFR、可寻址位、存储器和I/O口的定义 C51的运算符 函 数 C语言编程实例 单片机资源的C语言编程实例 汇编语言和C语言的混合编程 C语言函数库的管理与使用 小结,51系列单片机支持三种高级语言,即PL/M,C和BASIC。8052单片机内固化有解释BASIC语言 ,BASIC语言适用于简单编程而对编程效率运行速度要求不高的场合;PL/M是一种结构化的语言,很象PASCAL,PL/M 编译器好象汇编器一样产生紧凑的机器代码,可以说是高级汇编语言,但它
2、不支持复杂的算术运算,无丰富库函数支持,学习PL/M无异于学习一种新的语言。C语言是一种通用的程序设计语言,其代码率高,数据类型及运算符丰富,并具有良好的程序结构,适用于各种应用的程序设计,是目前使用较广的单片机编程语言。,单片机的C语言采用C51编译器(简称C51)。由C51产生的目标代码短、运行速度高、所需存储空间小、符合C语言的ANSI标准,生成的代码遵循Intel目标文件格式,而且可与A51汇编语言或PL/M51语言目标代码混和使用。,应用C51编程具有以下优点: (1)C51管理内部寄存器和存贮器的分配,编程时,无需考虑不同存储器的寻址和数据类型等细节问题; ()程序由若干函数组成,
3、具有良好的模块化结构;()有丰富的子程序库可直接引用,从而大大减少用户编程的工作量。()C语言和汇编语言可以交叉使用. 汇编语言程序代码短、运行速度快、但复杂运算编程耗时。如果用汇编语言编写与硬件有关的部分程序,用C语言编写与硬件无关的运算部分程序,充分发挥两种语言的长处,可以提高开发效率。,10.1 C51程序结构,同标准C一样,C51的程序由一个个函数组成,这里的函数和其他语言的“子程序”或“过程 ”具有相同的意义。其中必须有一个主函数main(),程序的执行从main()函数开始,调用其 他函数后返回主函数main(),最后在主函数中结束整个程序而不管函数的排列顺序如何。,C语言程序的组
4、成结构如下所示:,全局变量说明 /*可被各函数引用*/ main() /*主函数*/ 局部变量说明 /*只在本函数引用*/执行语句(包括函数调用语句) fun1(形式参数表) /*函数1*/ 形式参数说明,局部变量说明 执行语句(包括调用其他函数语句)funn(形式参数表) /*函数n*/形式参数说明 局部变量说明 执行语句,C语言的语句规则: 1. 每个变量必须先说明后引用,变量名英文大小写是有差别的。 2. C语言程序一行可以书写多条语句,但每个语句必须以“;”结尾,一个语句也可以多行书写为好。 3. C语言的注释用/*/表示。 4. “”花括号必须成对,位置随意,可在紧挨函数名后,也可另
5、起一行,多个花括号可以同行书写,也可逐行书写,为层次分明,增加可读性,同一层的“”花括号对齐,采用逐层缩进方式书写。,10.2 C51的数据类型,C51的数据有常量和变量之分。 常量在程序运行中其值不变的量,可以为字符,十进制数或十六进制数(用0 x表示)。 常量分为数值型常量和符号型常量,如果是符号型常量,需用宏定义指令(#define)对其进行定义(相当于汇编的“EQU”伪指令)如: #define PI 3.1415 那么程序中只要出现PI的地方,编译程序都译为3.1415。 变量在程序运行中其值可以改变的量。 一个变量由变量名和变量值构成,变量名即是存贮单元地址的符号表示,而变量的值就
6、是该单元存放的内容。定义一个变量,编译系统就会自动为它安排一个存贮单元,具体的地址值用户不必在意。,10.2.1 C51变量的数据类型,无论哪种数据都是存放在存贮单元中的,每一个数据究竟要占用几个单元(即数据的长度)都要提供给编译系统,正如汇编语言中存放数据的单元要用DB或DW伪指令进行定义一样,编译系统以此为根据预留存贮单元,这就是定义数据类型的意义.C51编译器支持数据类型见表10.1。,表10-1 C51的数据类型,对表10.1作如下说明: 1. 字符型(char)、整型(int)和长整型(long)均有符号型(signed)和无符号型(unsigned)两种,如果不是必须,尽可能选择u
7、nsigned型,这将会使编译器省却符号位的检测,使生成的程序代码比signed类型短得多。 2. 程序编译时,C51编译器会自动进行类型转换,例如将一个位变量赋值给一个整型变量时,位型值自动转换为整型值;当运算符两边为不同类型的数据时,编译器先将低级的数据类型转换为较高级的数据类型,运算后,运算结果为高级数据类型。 3. 51单片机内部数据存贮器的可寻址位(20H2FH)定义为bit型,而特殊功能寄存器的可寻址位(即地址为X0H和X8H的SFR的各位)只能定义为sbit类型。,10.2.2 关于指针型数据,(1)关于指针型变量 在汇编语言程序中,要取存贮单元m的内容可用直接寻址方式,也可用寄
8、存器间接寻址方式 ,如果用R1寄存器指示m的地址,用R1取m单元的内容。相对应的在C语言中用变量名表示取变量的值(相当于直接寻址),也可用另一个变量(如P)存放m的地址,P就相当于R1寄存器 。用*P取得m单元的内容(相当于汇编的间接寻址方式)这里P即为指针型变量。下面表格表示两种语言将m单元的内容送n单元的对照语句。,注: 上表省略了汇编语言程序中对符号地址n和m用EQU伪指令进行具体地址定义的 语句以及C语言对变量n、m和指针变量P进行类型定义的语句,实际程序设计中,此步是不可 缺少的。表中&为取地址运算符,*为取内容运算符。,表1O-2 汇编语言和C语言的对照,(2)指针型数据的类型 由
9、于C51是结合51单片机硬件的,51单片机的不同存贮空间,有不同的地址范围,即使对于同一外部数据存贮器,又有用Ri分页寻址(Ri为八位)和用DPTR寻址(DPTR为十六位)两种寻址方式,而指针本身也是一个变量,有它存放的存贮区和数据长度。因此,在指针类型的定义中要说明:被指的变量的数据类型和存贮类型;指针变量本身的数据类型(占几个字节)和存贮类型(即指针本身存放在什么存贮区)。 例如类型定义为data或idata,表示指针指示内部数据存贮器;而pdata表示指针指向外部数据存贮器,用Ri间址。以上均为八位地址;而类型code/xdata表示指针指向外部程序存贮器或外部数据存贮器指针,本身(即被
10、指 示地址)应为十六位长度。如果想使指针能适用于指向任何存贮空间,则可以定义指针为通用型,此时指针长度为3字节,第一字节表示存贮器类型编码,第二、三字节分别表示所指 地址的高位和低位。第一字节表示的存贮器类型编码见表10-3:,表10-3 通用型指针的存贮类型编码,10.3 数据的存贮类型和存贮模式,10.3.1数据的存贮类型 C51是面向8XX51系列单片机及硬件控制系统的开发语言,它定义的任何变量必须以一定的存贮类型的方式定位在8XX51的某一存贮区中,否则便没有意义。因此在定义变量类型时,还必须定义它的存贮类型,C51的变量的存贮类型如表10-4所示:,表10-4 C51的变量的存贮类型
11、,访问内部数据存贮器(idata)比访问外部数据存贮器(xdata)相对要快一些,因此,可将经常使用的变量置于内部数据存贮器中,而将较大及很少使用的数据变量置于外部数据存贮器中。例如定义变量x语句:data char x (等价于char data x)。如果用户不对变量的存贮类型定义,则编译器承认默认存贮类型,默认的存贮类型由编译控制命令的存贮的模式部分决定。,10.3.2 存贮器模式,存贮器模式决定了变量的默认存贮器类型、参数传递区和无明确存贮区类型的说明。C51的存贮器模式有SMALL、LARGE和COMPACT(见表10-5)。 在固定的存贮器地址进行变量参数传递是C51的一个标准特征
12、,在SMALL模式下参数传递是在内部数据存贮区中完成的。LARGE和COMPACT模式允许参数在外部存贮器中传递。C51同时也支持混 合模式,例如在LARGE模式下生成的程序可将一些函数分页放入SMALL模式中从而加快执行速度。,例如设C语言源程序为PROR.C,若使程序中的变量类型和参数传递区限定 在外部数据存贮区 ,有两种方法: 方法1:用C51对PROR.C进行编译时,使用命令C51 PROR.C COMPACT。 方法2:在程序的第一句加预处理命令 #pragma compact,表10-5 存贮器模式,10.3.3 变量说明举例,data char var; /*字符变量var定位在
13、片内数据存贮区*/ char code MSG=PARAMETER:; /*字符数组MSG 定位在程序存 贮区*/unsigned long xdata array100; /*无符号长型数组定位在片外RAM区,每元素占4bytes*/ float idata x,y,z; /*实型变量x,y,z,定位在片内用间址访问的内部 RAM区*/ bit lock; /*位变量Lock定位在片内RAM可位寻址区*/unsigned int pdata sion; /*无符号整型变量sion定位在分页的外部RAM*/unsigned char xdata vector1044 /*无符号字符型三维数组,
14、 定位在片外RAM区*/ sfr P0=0 x80; /*定义P0口,地址为80H*/char bdata flags; /*字符变量flags定位在可位寻址内部RAM区*/ sbit flag0=flags0; /*定义flag0为flags.0 */,如果在变量说明时略去存贮器类型标志符,编译器会自动选择默认的存贮器类型。默认的存贮器类型由控制指令SMALL、COMPACT和LARGE限制。例如如果声明char var,则默认的存贮器模式为SMALL,var放在data存贮区;如果使用COMPACT模式,var放入idata存贮区 ;在使用LARGE模式的情况下,var被放入外部数据存贮区
15、(xdata存贮区)。 10.3.4指针变量说明举例long xdata *px; /*指针px指向long型xdata区(每个数据占四个单元,指针自身在默认存贮器(如不指定编译模式在data区),指针长度为2个字节*/char xdata *data pd;/*指针pd指向字符型xdata区,自身在data区,长度2字 节*/data char xdata *pd; /*与上例等效*/ data int *pn;(和int *data pn及intr*pn等效) /*定义一个类型为int型的通用型指针,指针自身在data区长度为3字节*/,在上例的指针声明中包含如下几个内容:1) 1) 指针
16、变量名(如px)前面冠以“*”,表示px为指针型变量,此处*不带取内容之意。 2) 指针指向的存贮类型,即指向哪个存贮区,它决定了指针本身的长度(见表10.1)。存贮类型声明的位置在数据类型和指针名(如*px)之间,如无次项声明,则此指针型变量为通用型。 3) 3) 指针指向的存贮区的数据类型,即被指向的存贮区以多少个单元作一个数据单位,当程序通过指针对该区操作时,将按此规定的单元个数的内容作为一个数据操作。 4) 指针变量自身的存贮类型,即指针处于什么区与自身的长度无关,该声明可位于声明语句的开头,也可在“*”和变量名之间。此项由编译模式放在默认区,如无规定编译模式,通常在data区。,10
17、.4 C51对SFR、可寻址位、存储器和I/O口的定义,10.4.1 特殊功能寄存器SFR定义 C51提供了一种自主形式的定义方式,使用特定关键字sfr 如 sfr SCON=0 x98; /*串行通信控制寄存器地址98H*/ sfr TMOD=0 x89; /*定时器模式控制寄存器地址89H*/ sfr ACC=0 xe0; /*A累加器地址E0H*/ sfr P1=0 x90; /*P1端口地址90H*/ 定义了以后,程序中就可以直接引用寄存器名。 C51也建立了一个头文件reg51.h (增强型为reg52.h),在该文件中对所有的特殊功能寄存器的进行了sfr定义, 对特殊功能寄存器的有
18、位名称的可寻址位进行了sbit定义,因此,只要用包含语句#include,就可以直接引用特殊功能寄存器名,或直接引用位名称。要特别注意:在引用 时特殊功能寄存器或者位名称必须大写。,10.4.2 对位变量的定义,C51对位变量的定义有三种方法: 1. 将变量用bit类型的定义符定义为bit类型: 如 bit mn; mn为位变量,其值只能是“0”或“1”,其位地址C51自行安排在可位寻址区的bdata区。 2. 采用字节寻址变量.位的方法: 如 bdata int ibase; /*ibase定义为整型变量*/ sbit mybit=ibase15; /*mybit定义为ibase的D15位*
19、/ 这里位是运算符“”相当于汇编中的“”,其后的最大取值依赖于该位所在的字节寻址变量的定义类型,如定义为char最大值只能为7。,3. 对特殊功能寄存器的位的定义 方法1:使用头文件及sbit定义符;多用于无位名的可寻址位。 例如 #include sbit P1-1=P11; /*P1-1为P1口的第1位*/ sbit ac=ACC7; /*ac定义为累加器A的第7位*/ 方法2:使用头文件reg51.h,再直接用位名称。 例如 #include RS1=1; RS0=0; 方法3:用字节地址位表示 例如 sbit OV=0 xD02; 方法4:用寄存器名.位定义 例如 sfr PSW=0
20、xd0; /*定义PSW地址为d0H*/ sbit CY=PSW7; /*CY为PSW7*/,10.4.3 C51对存贮器和外接I/O口的绝对地址访问,1.对存贮器的绝对地址访问 利用绝对地址访问的头文件absacc.h可对不同的存贮区进行访问。该头文件的函数有: CBYTE (访问code区字符型) DBYTE (访问data区字符型) PBYTE (访问pdata或I/O区字符型) XBYTE (访问xdata或I/O区字符型) 还有CWORD、DWORD、PWORD和XWORD四个函数,它们的访问区域同上,只是访问的类型为int 型。例10-1 #include #define com
21、XBYTE0 x07ff 那么后面程序com变量出现的地方,就是对地址为07ffH的外部RAM或I/O口进行访问。,例10-2 XWORD0=0 x9988; 即将9988H(int类型)送入外部RAM的0号和1号单元。 使用中要注意:absacc.h一定要包含进程序,XBYTE必须大写。 2.对外部I/O口的访问 由于单片机的I/O口和外部RAM统一编址,因此对I/O口地址的访问可用XBYTE (MOVX DPTR )或PBYTE (MOVX Ri)进行。例10-3 XBYTE0Xefff=0 x10;将10H输出到地址为EFFFH端口,10.5 C51的运算符,1赋值运算符: 将“”的右边
22、的值赋值给左边的变量.2. C51的算术运算符: (加或正号); (减或负号);* (乘号); / (除号); % (求余)优先级为:先乘除,后加减,先括号内,再括号外3. C51的关系运算符有六种:(小于); (大于); = (小于等于); = (大于等于); =(相等);!= (不相等)优先级:前四个高,后二个“=”和“!=”级别低。,4C51的逻辑运算符有三种: 逻辑表达式和关系表达式的值相同,以0代表假,以1代表真。以上三种运算的优先级见图10.1。 5C51的按位操作的运算符有六种:&(按位与);(按位或); (按位异或); (位取反); (位右移 ) (注:补零移位)例1. a=0
23、 xf0H; 表达式a=a值为0FH例2. a=0 xea; 表达式a2值为A8H,即a值左移两位,移位后空白位补0。 6. 自增、自减运算符: +i,-i (在使用i之前,先使i值加1,减1) i+,i- (在使用i之后,再使i值加1.,减1) 例设i原值为5 j=+i 则j值为6,i值也为6 j=i+ 则j值为5,i值为6,| 非算术运算关系运算&和|= 赋值运算,图10-1 运算符的优先级,7复合赋值运算符:+=;=;*=;/=;%=;=;&=;=;|=。例:a+=b相当于a=a+b。a=7. 相当于a=a 7.。 8. 对指针操作的运算符: &取地址运算 *间址运算符例 a=&b;取b
24、变量的地址送变量a c=*b;将以b的内容为地址的单元的内容送c这里要注意: “&”与按位与运算符的差别,如果“&”为“与”,&的两边必须为变量或常量; “*”与指针定义时指针前的“*”的差别。如char *pt,这里的“*”只表示pt为指针变量,不代表间址取内容的运算。,10.6 函 数,C语言程序由函数组成,下面介绍函数的要点。10.6.1 函数的分类及定义 从用户使用角度划分,函数分为库函数和用户自定义函数。 库函数是编译系统为用户设计的一系列标准函数(见本书附录二),用户只需调用,而无需自己去编写这些复杂的函数,如前面所用到的头文件reg51.h、absacc.h等,有的头文件中包括一
25、系列函数,要使用其中的函数必须先使用#include包含语句,然后才能调用。用户自定义函数是用户根据任务编写的函数从参数形式上函数分为无参函数和有参函数。有参函数即是在在调用时,调用函数用实际参数代替形式参数,调用完返回结果给调用函数。,10.6.2 函数的定义,函数以“”开始,以“”结束。 无参函数的定义:返回值类型 函数名() 函数体语句 如果函数没有返回值,可以将返回值类型设为void。 有参函数的定义: 返回值类型 函数名(形式参数表列) 形式参数类型说明 函数体语句 return(返回形参名) 也可以这样定义 返回值类型 函数名(类型说明 形式参数表列) 函数体语句 return(返
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 单片机 ppt 课件 语言 编程
链接地址:https://www.31ppt.com/p-1405832.html