单片机C语言编程基础知识专题培训ppt课件.ppt

上传人:小飞机 文档编号:2330397 上传时间:2023-02-11 格式:PPT 页数:52 大小:1.82MB
返回 下载 相关 举报
单片机C语言编程基础知识专题培训ppt课件.ppt_第1页
第1页 / 共52页
单片机C语言编程基础知识专题培训ppt课件.ppt_第2页
第2页 / 共52页
单片机C语言编程基础知识专题培训ppt课件.ppt_第3页
第3页 / 共52页
单片机C语言编程基础知识专题培训ppt课件.ppt_第4页
第4页 / 共52页
单片机C语言编程基础知识专题培训ppt课件.ppt_第5页
第5页 / 共52页
点击查看更多>>
资源描述

《单片机C语言编程基础知识专题培训ppt课件.ppt》由会员分享,可在线阅读,更多相关《单片机C语言编程基础知识专题培训ppt课件.ppt(52页珍藏版)》请在三一办公上搜索。

1、1,2,3,4,C语言编程的基本概念和知识,5,1标识符,标识符是用来表示源程序中自定义对象名称的符号。其中的自定义对象可以是常量、变量、数组、结构、语句标号以及函数等。在C51语言中,标识符可以由字母(az,AZ)、数字(09)和下划线“_”组成,最多可支持32个字符。,C51标识符的定义不是随意的,应遵循“简洁”和“见名知意”的原则,并需要符合一定的规则:标识符的第一个字符必须是字母或者下划线,不能为数字。由于有些编译系统专用的标识符以下划线开头,所以用户在定义标识符时一般不要以下划线开头。C51的标识符区分大小写,例如“ch1”和“Ch1”表示两个不同的标识符。用户自定义的标识符不能与系

2、统保留的关键字重复。,6,2关键字,关键字是C51编译器保留的一些特殊标识符,具有特定的含义和用法。单片机C51程序语言继承了ANSI C标准定义的32个关键字,如表7-1所示。,表7-1 C51的关键字,同时C51又结合单片机硬件的特点扩展了19个关键字:_at_ idata sfr16 alien interrupt small bdata large _task_ code bit pdata using reentrant xdata compact sbit data sfr,7,表7-2列出了Keil uVision2 C51编译器所支持的数据类型。,表7-2 C51编译器所支持的

3、数据类型,8,1char字符类型char类型的长度是一个字节,通常用于定义处理字符数据的变量或常量。char字符类型分为无符号字符类型(unsigned char)和有符号字符类型(signed char),默认值为signed char类型。unsigned char类型用字节中所有的位来表示数值,可以表达的数值范围是0255;signed char类型中字节最高位表示数据的符号,“0”表示正数,“1”表示负数(负数用补码表示),所能表示的数值范围是-128+127。,9,2int整型int整型长度为两个字节,用于存放一个双字节数据。分为有符号整型数signed int和无符号整型数unsi

4、gned int,默认值为signed int类型。signed int表示的数值范围是-32768+32767,字节中最高位表示数据的符号,“0”表示正数,“1”表示负数;unsigned int表示的数值范围是065535。,3long长整型long长整型长度为四个字节,用于存放一个四字节数据。分有符号长整型signed long和无符号长整型unsigned long,默认值为signed long类型。signed int表示的数值范围是-2147483648+2147483647,字节中最高位表示数据的符号,“0”表示正数,“1”表示负数;unsigned long表示的数值范围是0

5、4294967295。,10,11,9sbit可位寻址位sbit是C51中的一种扩充数据类型,利用它可以访问芯片内部的RAM中的可寻址位或特殊功能寄存器中的可寻址位。定义格式:sbit 变量名=位地址;sbit 变量名=SFR地址位序号;sbit 变量名=sfr16变量位序号。因P1端口的寄存器是可位寻址的,所以我们可以定义P1_1为P1中的P1.1引脚,同样我们可以用P1.1的地址去写,这样在以后的程序语句中就可以用P1_1来对P1.1引脚进行读写操作了。例如:sbit P1_1=P11;sbit P1_1=0 x91;,8sfr16 16位特殊功能寄存器sfr16是一种扩充数据类型,占用两

6、个内存单元,sfr16和sfr一样用于操作特殊功能寄存器,所不同的是,此类型的变量可访问16为特殊功能寄存器。定义格式:sfr16 变量名=变量地址。此处的变量地址为16位中的低8位地址,其地址范围为0 x800 xFF。通过sfr16变量读16位特殊功能寄存器时,先读低字节,后读高字节;写特殊功能寄存器时先写高字节,后写低字节。,12,(2)浮点型常量浮点型常量可分为十进制和指数表示形式。十进制浮点型常量由数字和小数点组成,整数或小数部分为0,可以省略但必须有小数点,如0.888,3345.345,0.0等。指数浮点型常量表示形式为:数字.数字e数字 中的内容为可选项,如125e3,7e9,

7、-3.0e-3等。,1常量常量是在程序运行过程中不能改变的量,如固定的数据表、字符等。常量的数据类型只有整型、浮点型、字符型、字符串型和位标量。,(1)整型常量不同数据类型的整型常量表示方法不同,十进制如123,0,-89等;十六进制则以0 x开头如0 x34,-0 x3B等;长整型就在数字后面加字母L,如104L,034L,0 xF340等。,13,1常量常量是在程序运行过程中不能改变的量,如固定的数据表、字符等。常量的数据类型只有整型、浮点型、字符型、字符串型和位标量。,(3)字符型常量字符型常量是单引号内的字符,如a,d等。表示不显示的控制字符,可以在该字符前面加一个反斜杠“”组成专用转

8、义字符,常用转义字符如表7-3所示。,表7-3 常用转义字符表,14,1常量常量是在程序运行过程中不能改变的量,如固定的数据表、字符等。常量的数据类型只有整型、浮点型、字符型、字符串型和位标量。,(4)字符串型常量字符串型常量由双引号内的字符组成,如“test”,“OK”等。当引号内没有字符时,为空字符串。在C中字符串常量是做为字符类型数组来处理的,在存储字符串时系统会在字符串尾部加上“0”转义字符以作为该字符串的结束符。字符串常量“A”和字符常量A是不同的,前者在存储时多占用一个字节的空间。,15,(5)位标量位标量是C51编译器的一种扩充数据类型,它的值是一个二进制位,不是0就是1。下面我

9、们来看一些常量定义的例子:#define False 0 x0;/用预定义语句可以定义常量,这里定义False为0,True 为1#define True 0 x1;/在程序中用到False编译时自动用0替换,同理True替换为1unsigned int code a=100;/这一句用code把a定义在程序存储器中并赋值const unsigned int c=100;/用const定义c为无符号int常量并赋值以上两句它们的值都保存在程序存储器中,而程序存储器在运行中是不允许被修改的,所以如果在这两句后面用了类似a=110,a+这样的赋值语句,编译时将会出错。,1常量常量是在程序运行过程中

10、不能改变的量,如固定的数据表、字符等。常量的数据类型只有整型、浮点型、字符型、字符串型和位标量。,16,2变量,17,(1)变量的定义和作用范围定义一个变量的格式如下:存储类型 数据类型 存储器类型 变量名表在定义格式中除了数据类型和变量名表是必要的,其他都是可选项。存储类型不同存储类型的变量以及不同位置定义的变量具有不同的代码有效范围,也就是变量的作用域。在单片机程序中,按照变量的存储类型,可以分为:自动变量、全局变量、静态变量和寄存器变量。,2变量,18,存储类型,19,存储器类型,存储器类型的说明就是指定该变量在C51硬件系统中所使用的存储区域,并在编译时准确的定位。表7-4中是KEIL

11、 uVision2所能认别的存储器类型。,表7-4 存储器类型,20,如果省略存储器类型,系统则会按编译模式small,compact或large所规定的默认存储器类型去指定变量的存储区域。,21,对变量进行绝对定位,C51扩展的关键字_at_专门用于对变量作绝对定位,_at_使用在变量的定义中,其格式为:存储类型 数据类型 存储区 变量名1 _at_ 地址常数,变量名2,例如:对data区域中的 unsigned char变量aa作绝对定位:unsigned chardata aa _at_ 0 x30;对pdata区域中的 unsigned int数组cc作绝对定位:unsigned in

12、t pdata cc10 _at_ 0 x34;对xdata区域中的 unsigned char变量printer_port作绝对定位:unsigned charxdata printer_port _at_ 0 x7fff;,22,对变量进行绝对定位,对变量绝对定位的几点说明:,23,(2)变量的初始化和赋值,变量的初始化,变量的初始化是指变量在被说明的同时赋给一个初值。外部变量和静态全程变量在程序开始处被初始化,局部变量包括静态局部变量是在进入定义它们的函数或复合语句时才作初始化。所有全程变量在没有明确的初始化时将被自动清零,而局部变量和寄存器变量在未赋值前其值是不确定的。,对于外部变量和

13、静态变量,初值必须是常数表达式,而自动变量和寄存器变量可以是任意的表达式,这个表达式可以包括常数和前面说明过的变量和函数。,24,例如:,float f0,f1=0.2;/定义全程变量,在初始化时f0被清零,f1被赋0.2main()static int i=10,j;/定义静态局部变量,初始化时i被赋10,j不确定int k=i*5;/定义局部变量,初始化时k 被赋10*5=50char c=y;/定义字符型指什变量并初始化,变量的初始化,25,变量的赋值,变量赋值是给已说明的变量赋给一个特定值。单个变量的赋值:整型变量和浮点变量。赋值格式如下:变量名=表达式;,例如:,main()int

14、a,m;/定义局部整型变量a,mfloat n;/定义局部浮点变量na=100,m=20;/给变量赋值n=a*m*0.1;,main()int a,b,c;a=b=c=0;/同时给a,b,c赋值,26,变量的赋值,字符型变量。字符型变量可以用三种方法赋值。,例如:,main()char a0,a1,a2;/定义局部字符型变量a0,a1,a2a0=b;/将字母b赋给a0a1=50;/将十进制数字2的ASCII值50赋给a1a2=x0d;/将回车符赋给a2,27,28,29,单片机C程序的运算符和表达式如下:,30,算术运算符是执行算术运算时的操作符,包括四则运算和取模运算符,如表7-5所示。,表

15、7-5 算术运算符,31,关系运算符用来对两个变量的大小进行判断的,如表7-6所示。,表7-6 关系运算符,32,逻辑运算符就是执行逻辑运算功能的操作符号,包括与(AND)、或(OR)、非(NOT),逻辑运算的最终结果为真(值为1)或假(值为0),如表7-7所示。,表7-7 逻辑运算符,33,布尔“位”运算符与逻辑运算符比较相似,不同之处在于逻辑运算的最终结果为真或假,而布尔“位”运算符的结果是一个具体数据。布尔“位”运算符如表7-8所示。,表7-8 布尔“位”运算符,34,赋值运算符包括“=”运算符,还有算术运算符,逻辑运算符等,如表7-9所示。,表7-9 赋值运算符,35,递增/递减运算符

16、也是一种比较有效的运算符,包括自增与自减运算符,如表7-10所示。,表7-10 递增/递减运算符,36,运算符的优先级如表7-11所示。,表7-11 运算符的优先级,37,38,39,循环指令就是将程序流控制在指定的循环里,直到符合指定条件才结束循环,继续往下执行。Keil C所提供的循环指令有for语句、while语句、do-while语句。,1计数循环,for语句是一个很实用的计数循环,其格式如下:for(表达式1;表达式2;表达式3)指令;break;例如:for(int i=0;i0;x-)for(;);,2前条件循环,while语句将判断条件放在语句之前,称为前条件循环,其格式如下:

17、while(表达式)指令;break;,3后条件循环,do-while语句提供先执行再判断的功能,称为后条件循环,其格式如下:do 指令;break;while(表达式);,40,选择指令的功能是根据条件决定程序的流程,Keil C所提供的选择指令有if-else语句及switch-case语句。,if-else语句提供条件判断的语句,称为条件选择语句,其格式(如下)与流程图(如图7-1):if(表达式)指令区域1;else 指令区域2;,图7-1 if-else条件选择流程图,if的多重条件判断语句如下,其流程图如图7-2所示。if(表达式1)指令区域1;else if(表达式2)指令区域2

18、;else if(表达式3)指令区域3;else 指令区域4;,图7-2 if-else 条件判断多重选择流程图,1条件选择,41,2多分支选择,switch-case语句提供多重选择,就像是波段开关一样,称为多分支选择语句。这种选择方式不会有优先等级的问题,其格式如下,switch-case语句的流程图如图7-3所示。switch(表达式)case(常数1);指令区域1;break;case(常数2):指令区域2;break;default:指令区域n;break;,图7-3 switch-case多重选择流程图,42,43,数组也是一种变量,将一堆相同数据形态的变量,以一个相同的变量名称来

19、表示。既然是一种变量,使用之前就得声明,其声明格式如下:数据类型 数组名数组大小例如声明一个含有5个字符的数组:char LPC5;这个数组包括LPC0LPC4等5个字符,是字符的数组,相当于常说的“字符串”。但是Keil C没有“字符串”数据类型,所以用字符数组来代替字符串变量。声明数组的同时也可以赋初值,如 char LPC5=ABCD经过上述声明后,LPC0=A,LPC1=B,LPC2=C,LPC3=D,LPC4=0。,数组(array)是一种将同类型数据集合管理的数据结构,而指针(Pointer)是存放存储器地址的变量,因此,数组与指针可谓是数据管理的好帮手。,若不知道数组的大小可不填

20、数组大小,而由程序来处理,例如:char string1=welcome to hua dong jiao da li gong xue yuan如果声明整数(int)或浮点数(float)数组,也要指定其初始值,可利用大括号实现,语句如下:int Num6=30,22,33,44,55,66;若要定义多维数组,可以按如下形式:数据类型 数组名数组大小1数组大小2数组大小n;如:int Num32=10,11,12,13,14,15;,1数组,44,2指针,指针是用来存放存储器地址的变量,既然是变量,使用前均需要先定义才能使用。数据类型*变量名称;通常指针都采用整数数据类型,例如要声明一个名为

21、ptr的指针,语句如下:int*ptr;也可以将同类型的变量与指针放在一起声明,语句如下:int*ptr1,*ptr2,a,b,c;与指针息息相关的运算符是“,执行以上语句后,a变量的地址就被放入ptr1指针变量。当然,这些操作主要是针对数组,通常会先取得数组的第一个元素的地址,如ptr1=,45,46,函数(Function)和中断子程序都属于子程序。也可以称函数为子程序,称中断子程序为中断函数。,1函数,函数的结构与主程序的结构类似,不过函数还能传入自变量,其结构如下:void Sub_name(int x)int i,j;unsigned char LED;LED=0 xff;/*关闭L

22、ED*/其中,void为传出自变量,Sub_name为函数名,x为传入自变量,“int i,j;和unsigned char LED;”为变量声明区,“LED=0 xff;/*关闭LED*/”为程序区。,47,中断子程序的结构与函数的结构类似,不过中断子程序不能传入自变量,也不返回值。而且使用中断子程序之前不需要声明,但需要在主程序中进行中断的相关设置。从中断子程序的第一行就可以看出它与一般函数的不同,如下所示:void 中断子程序名称(void)interrupt 中断编号 using 寄存器组,2中断子程序,interrupt右边标示中断编号,Keil C提供031等32个中断编号,不过8

23、051只使用04,8052则使用05,例如要声明为INT0外部中断,则标识为“interrupt 0”;若要声明为T0定时计数器中断,则标识为“interrupt 1”。using右边标示中断子程序里所要采用的寄存器组。8051内部有4组寄存器组,即RB0RB3。通常主程序使用RB0,根据需要在子程序里使用其他寄存器组,以避免数据的冲突。若不指定寄存器组,则可省略本项目。,48,49,所谓“预处理命令”,是指先经过预处理器处理后,才进行编译的命令。通常,除条件编译命令外,预处理命令放置于整个程序的开头。,1定义命令#define命令用来指定常数、字符串或宏函数的代名词,与汇编语言的“equ”、

24、“reg”命令一样,#define命令的格式如下:#define 代名词 常数(字符串或宏函数)比如要从P0口输出,则可以将outputs定义为P2,语句如下。#define outputs P2经过上述定义后,如果在程序中要输出到P2的指令,就可以用output代替,语句如下:outputs=0 xff;/*输出 1111 1111*/进行编译时,预处理器会将整个程序里的所有“outputs”替换为P2,所以将这个指令改为:P2=0 xff;/*输出 1111 1111*/,50,#include命令的功能是将指定的定义或声明等文件放入程序之中。常用于引入标准库函数文件,下面介绍一些常用的C

25、51头文件:absacc.h包含允许直接访问8051不同存储区的宏定义;assert.h文件定义assert 宏,可以用来建立程序的测试条件;ctype字符转换和分类程序;intrins.h文件包含指示编译器产生嵌入式固有代码的程序的原型;math.h数学程序;reg51.h51的特殊寄存器;reg52.h52的特殊寄存器;setjmp.h定义jmp_buf类型和setjmp和longjmp程序的原型;stdarg.h可变长度参数列表程序;stdlib.h存储区分配程序;stdio.h标准输入和输出程序;string.h字符串操作程序、缓冲区操作程序。对于常用的MCS-51单片机,必须包含reg51.h的头文件,因为该文件对51单片机的相关寄存器及位进行了定义,这样在程序中才可以使用这些资源。,2包含命令,51,C语言是一种可移植性很高的程序语言,源程序可在不同版本的C语言编译器下进行编译。当然,不同的C语言编译器提供不同的资源与指令语法。这时候,就可应用条件式编译命令来区分不同的编译器。在8051的程序设计里也可以应用条件式编译命令以适应不同的外围与控制方式。条件编译格式如下:#if 表达式 程序1#else 程序2#endif若表达式成立,则编译程序1,否则编译程序2。,3条件式编译命令,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号