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

上传人:sccc 文档编号:5812052 上传时间:2023-08-22 格式:PPT 页数:174 大小:1.33MB
返回 下载 相关 举报
单片机原理及应用C语言版4.ppt_第1页
第1页 / 共174页
单片机原理及应用C语言版4.ppt_第2页
第2页 / 共174页
单片机原理及应用C语言版4.ppt_第3页
第3页 / 共174页
单片机原理及应用C语言版4.ppt_第4页
第4页 / 共174页
单片机原理及应用C语言版4.ppt_第5页
第5页 / 共174页
点击查看更多>>
资源描述

《单片机原理及应用C语言版4.ppt》由会员分享,可在线阅读,更多相关《单片机原理及应用C语言版4.ppt(174页珍藏版)》请在三一办公上搜索。

1、单片机原理及应用(C语言版)第4章 单片机C语言及程序设计,主 编:周国运本章制作:周国运中国水利水电出版社,第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与汇编语言混合编程4.10 C51集成开发软件Keil C,目 录,第4章 单片机C语言及程序设计,本章主要讨论C51变量的定义和函数的定义,以及Keil C软件的使用等。本章内容的安排,认为读者已经学习过C语言,具有C语言

2、的基本知识,因此,本章内容完全是结合单片机来讲解,也就是补充C语言在单片机方面的概念、数据定义和函数定义等。通过本章学习,使读者能够比较顺利地编写C51程序。,4.1 C51概述,主要内容4.1.1 C语言编程的优势4.1.2 C51与ANSI C的区别4.1.3 C51扩展的关键字,4.1 C51概述,学习单片机C语言的必要性随着单片机性能的不断提高,C语言编译调试工具的不断完善,以及现在对单片机产品辅助功能的要求、对开发周期不断缩短的要求,使得越来越多的单片机编程人员转向使用C语言,因此有必要在单片机课程中讲授“单片机C语言”。“C51”概念:为了与ANSI C区别,把“单片机C语言”称为

3、“C51”,也称为“Keil C”。,4.1.1 C语言编程的优势,在编程方面,使用C51较汇编语言有诸多优势:1)编程容易 2)容易实现复杂的数值计算3)容易阅读与交流4)容易调试与维护程序5)容易实现模块化开发 6)程序可移植性好,4.1.2 C语言与ANSI 的区别,用汇编语言编写单片机程序时,必须要考虑其存储器的结构,尤其要考虑其片内数据存储器、特殊功能寄存器是否正确合理的使用,以及按照实际地址端口数据的处理。用C51编写程序,虽然不像汇编语言那样需要具体地组织、分配存储器资源,但是C51对数据类型和变量的定义,必须要与单片机的存储结构相关联,否则编译器不能正确地映射定位。,4.1.2

4、 C语言与ANSI 的区别,用C51编写单片机程序,与用ANSI C编写程序的不同之处是,需要根据单片机存储器结构及内部资源,定义相应的数据类型和变量。其它的语法规定、程序结构及程序设计方法,都与ANSI C相同。所以本章主要介绍C51各种变量的定义、指针定义、函数定义和混合编程。,4.1.3 C51扩展的关键字,由于单片机在结构及编程上的特殊要求,C51有自己的特殊关键字,称之为C51扩展的关键字,下面给出常用的C51扩展的关键字。_at_bdatabit codedataidata interruptpdatareentrant sbitsfrsfr16usingvolatilexdata

5、这些关键字在后面会陆续接触到,此处先不给出它们的含义。,4.2 C51数据类型及存储,主要内容4.2.1 C51的数据类型4.2.2 C51数据的存储,4.2.1 C51的数据类型,4.2.1 C51的数据类型,数据类型转换1)自动转换转换规则是向高精度数据类型转换、向有符号数据类型转换。如字符型变量与整型变量相加时,则位变量先转换字符型或整型数据,然后相加。2)强制转换像ANSI C一样,通过强制类型转换的方式进行转换。如:unsignedintb;floatc;b=(int)c;,4.2.2 C51数据的存储,MCS-51单片机只有bit和unsigned char两种数据类型支持机器指令

6、,而其它类型的数据都需要转换成bit或unsigned char型进行存储。为了减少单片机的存储空间和提高运行速度,要尽可能地使用unsigned char型数据。一、位变量的存储bit和sbit型位变量,直接存于RAM的位寻址空间,包括低128位和特殊功能寄存器位。,4.2.2 C51数据的存储,二、字符变量的存储字符变量(char):无论是unsigned char数据还是signed char数据,均为1个字节,能够被直接存储在RAM中,可以存储在00 x7f区域,也可以存储在0 x800 xff区域,与变量的定义有关。unsigned char数:可直接被MSC-51接受signed

7、char数据:用补码表示。需要额外的操作来测试、处理符号位,使用的是两种库函数,代码量大,运算速度降低。,4.2.2 C51数据的存储,三、整型变量的存储整型变量(int):不管是unsigned int数据还是signed int数据,均为2个字节,其存储方法是高位字节保存在低地址(在前面),低位字节保存在高地址(在后面)。,例如,整型变量的值为0 x1234,在内存中的存放如右图所示。signed int数据用补码表示。,地址低高,4.2.2 C51数据的存储,四、长整型变量的存储长整型变量(long)为4个字节,其存储方法与整型数据一样,是最高位字节保存的地址最低(在最前面),最低位字节

8、保存的地址最高(在最后面)。,如长整型变量的值为0 x12345678,在内存中的存放方法如右图所示。不管是unsigned long数据还是signed long数据。,地址低高,4.2.2 C51数据的存储,五、浮点型变量的存储浮点型变量(fload)占4个字节,用指数方式表示,其具体格式与编译器有关。对于Keil C,采用的是IEEE-754标准,具有24位精度,尾数的最高位始终为1,因而不保存。具体分布为:1位符号位,8位阶码位,23位尾数,如下图所示。,4.2.2 C51数据的存储,符号位S:1表示负数,0表示正数。阶码:用移码表示。如,实际阶码-126用1表示,实际阶码0用127表

9、示,即实际阶码数加上127得到阶码的表达数。阶码数值范围:-126+128。,4.2.2 C51数据的存储,例如浮点数-12.5符号位为1,12.5的二进制数为1100.1=1.1001E+0011,阶码数值为3+127=130=10000010B,尾数为1001。因此,其十六进制数为0 xC1480000,则存储结构如右图所示。,地址低高,说明:教材中存储结构是错的。,4.3 C51变量的定义及数据存储区域,主要内容4.3.1 C51变量的定义4.3.2 C51变量的存储类型4.3.3 C51变量的存储区域4.3.4 C51变量定义举例4.3.5 C51变量的存储模式4.3.6 C51变量的

10、绝对定位,4.3.1 C51变量的定义,C51变量定义的一般格式为:存储类型数据类型 存储区变量名1=初值,变量名2=初值,或存储类型存储区 数据类型 变量名1=初值,变量名2=初值,可见变量(非位变量)的定义由4部分组成,即在变量定义时,指定变量4种属性。数据类型:在前面的4.2中已经叙述过,对于变量名也无须多说,下面主要解释“存储类型”和“存储区”等概念。,4.3.2 C51变量的存储类型,存储类型这个属性我们仍沿用ANSI C的说法,尽量不改变原来的含义。按照ANSI C,C语言的变量有4种存储类型:动态存储(auto)静态存储(static)全局存储(extern)寄存器存储(regi

11、ster),4.3.2 C51变量的存储类型,一、动态存储动态(存储)变量:用auto定义的为动态变量,也叫自动变量。作用范围:在定义它的函数内或复合语句内部。当定义它的函数或复合语句执行时,C51才为变量分配存储空间,结束时所占用的存储空间释放。定义变量时,auto可以省略,或者说如果省略了存储类型项,则认为是动态变量。动态变量一般分配使用寄存器或堆栈。,4.3.2 C51变量的存储类型,二、静态存储静态(存储)变量:用static定义的为静态变量。分为内部静态和外部静态变量。内部静态变量:在函数体内定义的为内部静态变量。在函数内可以任意使用和修改,函数运行结束后会一直存在,但在函数外不可见

12、,即在函数体外得到保护。外部静态变量:在函数体外部定义的为外部静态变量。在定义的文件内可以任意使用和修改,外部静态变量会一直存在,但在文件外不可见,即在文件外得到保护。,4.3.2 C51变量的存储类型,三、外部存储外部(存储)变量:用extern声明的变量为外部变量,是在其它文件定义过的全局变量。用extern声明后,便可以在所声明的文件中使用。需要注意的是:在定义变量时,即便是全局变量,也不能使用extern定义。,4.3.2 C51变量的存储类型,四、寄存器存储寄存器(存储)变量:用register定义的变量为寄存器变量。寄存器变量存放在CPU的寄存器中,这种变量处理速度快,但数目少。C

13、51中的寄存器变量:C51的编译器在编译时,能够自动识别程序中使用频率高的变量,并将其安排为寄存器变量,用户不用专门声明。,4.3.3 C51变量的存储区域,变量的存储区属性是单片机扩展的概念,非常重要,它涉及到7个新的关键字。MCS-51单片机有四个存储空间,分成三类,它们是片内数据存储空间、片外数据存储空间和程序存储空间。MCS-51单片机有更多的存储区域:由于片内数据存储器和片外数据存储器又分成不同的区域,所以单片机的变量有更多的存储区域。在定义变量时,必须明确指出是存放在哪个区域。,4.3.3 C51变量的存储区域,4.3.4 C51变量定义举例,1)定义存储在data区域的动态uns

14、igned char变量:unsigned char data sec=0,min=0,hou=0;2)定义存储在data区域的静态unsigned char变量:static unsigned char 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区域的

15、动态unsigned char数组:unsigned char idata temp20;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 x5b,0 x4f,0 x66,0 x6d,0 x7d,0

16、x07,0 x7f,0 x6f;/定义共阴极数码管段码数组,4.3.5 C51变量的存储模式,存储模式:如果在定义变量时缺省了存储区属性,则编译器会自动选择默认的存储区域,也就是存储模式。变量的存储模式也就是程序(或函数)的编译模式。编译模式分为三种:小模式(small)、紧凑模式(compact)和大模式(large)。编译模式由编译控制命令决定。存储模式(编译模式)决定了变量的默认存储区域和参数的传递方法。,4.3.5 C51变量的存储模式,一、small模式在small模式下,变量的默认存储区域是“data”、“idata”,即未指出存储区域的变量保存到片内数据存储器中,并且堆栈也安排在

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

18、默认存储区域是“xdata”,即未指出存储区域的变量保存到片外数据存储器,最大变量数可达64KB,并且堆栈也安排在该区域中。large模式的特点:存储容量大,速度慢large模式下参数的传递方式:参数的传递也是通过片外数据存储器完成的。,4.3.5 C51变量的存储模式,C51支持混合模式:即可以对函数设置编译模式,所以在large模式下,可以对某些函数设置为compact模式或small模式,从而提高运行速度。默认编译模式:如果文件或函数未指明编译模式,则编译器按small模式处理。编译模式控制命令:“#pragma small(或compact、large)”应放在文件的开始。,4.3.6

19、 C51变量的绝对定位,C51有三种方式可以对变量(I/O端口)绝对定位:绝对定位关键字_at_、指针、库函数的绝对定位宏。对于后两种方式,在后面指针一节介绍。C51扩展的关键字_at_专门用于对变量作绝对定位,_at_使用在变量的定义中,其格式为:存储类型 数据类型 存储区 变量名1 _at_ 地址常数,变量名2,4.3.6 C51变量的绝对定位,举例说明_at_的使用方法1)对data区域中的 unsigned char变量aa作绝对定位:unsignedchardata aa _at_ 0 x30;2)对pdata区域中的 unsigned int数组cc作绝对定位:unsignedin

20、t pdata cc10 _at_ 0 x34;3)对xdata区域中的 unsigned char变量printer_port作绝对定位:unsignedcharxdata printer_port _at_ 0 x7fff;,4.3.6 C51变量的绝对定位,对变量绝对定位的几点说明:1)绝对地址变量在定义时不能初始化,因此不能对code型变量绝对定位;2)绝对地址变量只能够是全局变量,不能在函数中对变量绝对定位;3)绝对地址变量多用于I/O端口,一般情况下不对变量作绝对定位;3)位变量不能使用_at_绝对定位。,4.4 C51位变量的定义,主要内容4.4.1 bit型位变量的定义4.4.

21、2 sbit型位变量的定义,4.4.1 bit型位变量的定义,常说的位变量指的就是bit型位变量。C51的bit型位变量定义的一般格式为:存储类型 bit 位变量名1=初值,位变量名2=初值,bit位变量被保存在RAM中的位寻址区域(字节地址为0 x200 x2f,16字节)。例如:bitflag_run,receiv_bit=0;static bitsend_bit;,4.4.1 bit型位变量的定义,两点说明:1)bit型位变量与其它变量一样,可以作为函数的形参,也可以作为函数的返回值,即函数的类型可以是位型的;2)位变量不能定义指针,不能定义数组。,4.4.2 sbit型位变量的定义,对

22、于能够按位寻址的特殊功能寄存器、定义在位寻址区域的变量(字节型、整型、长整型),可以对其各位用sbit定义位变量。为了方便起见,分开讨论按位寻址的特殊功能寄存器中位变量的定义、按位寻址的变量中位变量的定义。,4.4.2 sbit型位变量的定义,一、特殊功能寄存器中位变量定义能够按位寻址的特殊功能寄存器中位变量定义的一般格式为:sbit位变量名 位地址表达式这里的位地址表达式有三种形式:直接位地址特殊功能寄存器名带位号字节地址带位号,4.4.2 sbit型位变量的定义,1、用直接位地址定义位变量这种情况下位变量的定义格式为:sbit位变量名 位地址常数这里的位地址常数范围为0 x800 xff,

23、实际是定义特殊功能寄存器的位。例如:sbitP0_0=0 x80;sbitP1_1=0 x91;sbitRS0=0 xd3;/定义PSW的第3位sbitET0=0 xa9;/定义IE的第1位,4.4.2 sbit型位变量的定义,2、特殊功能寄存器名带位号定义这时位变量的定义格式为:sbit位变量名 特殊功能寄存器名位号常数这里的位号常数为07。例如:sbitP0_3=P03;sbitP1_4=P14;sbitOV=PSW2;/定义PSW的第2位sbitES=IE4;/定义IE的第4位,4.4.2 sbit型位变量的定义,3、寄存器地址带位号定义位变量在这种情况下位变量的定义格式为:sbit位变

24、量名 特殊功能寄存器地址位号常数这里的位号常数同上,为07。例如:sbitP0_6=0 x806;sbitP1_7=0 x907;sbitAC=0 xd06;/定义PSW的第6位sbitEA=0 xa87;/定义IE的第7位,4.4.2 sbit型位变量的定义,4、几点说明1)用sbit定义的位变量,必须能够按位操作,而不能够对无位操作功能的位定义位变量。2)用sbit定义位变量,必须放在函数外面作为全局位变量,而不能在函数内部定义。3)用sbit每次只能定义一个位变量。4)对其它模块定义的位变量(bit型或 sbit型)的引用声明,都使用bit。5)用sbit定义的是一种绝对定位的位变量(因

25、为名字是与确定位地址对应的),具有特定的意义,在应用时不能像bit型位变量那样随便使用。,4.4.2 sbit型位变量的定义,二、位寻址区变量的位定义对bdata型变量(字节型、整型、长整型),被保存在RAM中的位寻址区,因此可以对bdata型变量各位作位变量定义。这样,既可以对bdata型变量作字节(或整型、长整型)操作,也可以作位操作。bdata型变量的位定义格式:sbit 位变量名 bdata型变量名位号常数,4.4.2 sbit型位变量的定义,bdata型变量为在此之前应该是定义过的,位号常数可以是07(8位字节变量),或015(16位整型变量),或031(32位字长整型变量)。例如:

26、unsignedchar bdataoperate;对operate的低4位作位变量定义:sbit flag_key=operate0;/键盘标志位sbit flag_dis=operate1;/显示标志位sbit flag_mus=operate2;/音乐标志位sbit flag_run=operate3;/运行标志位,4.5 C51特殊功能寄存器的定义,主要内容4.5.1 8位特殊功能寄存器的定义4.5.2 16位特殊功能寄存器的定义,4.5.1 8位特殊功能寄存器的定义,定义的一般格式为:sfr特殊功能寄存器名 地址常数地址常数范围:0 x800 xff。特殊功能寄存器定义例子(见reg

27、51.h、reg52.h等文件):sfrP0=0 x80;/定义P0寄存器sfrP1=0 x90;/定义P1口寄存器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位特殊功能寄存器的定义,几点说

28、明:1)定义特殊功能寄存器中的地址必须在0 x800 xff范围内。2)定义特殊功能寄存器,必须放在函数外面作为全局变量。3)用sfr或sfr16每次只能定义一个特殊功能寄存器。4)像sbit一样,用sfr或sfr16定义的是绝对定位的变量(因为名字是与确定地址对应的),具有特定的意义,在应用时不能像一般变量那样随便使用。,4.6 C51指针的定义,主要内容4.6.1 通用指针4.6.2 存储器专用指针4.6.3 指针变换4.6.4 C51指针应用,4.6 C51指针的定义,由于MCS-51单片机有三种不同类型的存储空间,并且还有不同的存储区域,因此C51指针的内容更丰富。指针除了具有像变量的

29、四种属性(存储类型、数据类型、存储区、变量名)外,按存储区,将指针分为通用指针和不同存储区域的专用指针。,4.6.1 通用指针,所谓通用指针,就是通过该类指针可以访问所有的存储空间。在C51库函数中通常使用这种指针来访问。通用指针用3个字节来表示:第一个字节:表示指针所指向的存储空间第二个字节:为指针地址的高字节第三个字节:为指针地址的低字节,4.6.1 通用指针,通用指针的定义与一般C语言指针的定义相同,其格式为:存储类型 数据类型*指针名1,*指针名2,例如:unsigned char*cpt;int*dpt;long*lpt;static char*ccpt;,通用指针的特点:定义简单访

30、问所有空间访问速度慢,4.6.2 存储器专用指针,所谓存储器专用指针,就是通过该类指针,只能够访问规定的存储空间区域。指针本身占用1个字节(data*,idata*,bdata*,pdata*)或2个字节(xdata*,code*)。存储器专用指针的一般定义格式为:存储类型 数据类型 指向存储区*指针存储区 指针名1,*指针存储区 指针名2,4.6.2 存储器专用指针,指向存储区:是指针变量所指向的数据存储空间区域。不能够缺省。指针存储区:是指针变量本身所存储的空间区域。缺省时认为指针存储区在默认的存储区域,其默认存储区域决定于所设定的编译模式。指向和指针存储区,两者可以是同一个区域,但多数情

31、况下不会是同一个区域。,4.6.2 存储器专用指针,存储器专用指针例子:unsigned char data*cpt1,*cpt2;signed int idata*dpt1,*dpt2;unsigned char pdata*ppt;signed long xdata*lpt1,*lpt2;unsigned char code*ccpt;上面所定义的指针虽然所指向的空间不同,但指针变量本身都存储在默认的存储区域。,4.6.2 存储器专用指针,又如:1)unsigned char data*idata cpt1,*idata cpt2;2)signed int idata*data dpt1,

32、*data dpt2;3)unsigned char pdata*xdata ppt;4)signed long xdata*lpt1,*xdata lpt2;5)unsigned char code*data ccpt;绿色关键字为指针所指向的存储区蓝色关键字为指针本身所存储的区域,4.6.2 存储器专用指针,注意:(1)要区分指针变量指向的空间区域和指针变量本身所存储的区域;(2)定义时,前者不能缺省,而后者可以缺省;(3)指针变量的长度:指向不同的区域,占用的字节数不同。说明:指针变量本身所存储的区域,在定义指针时一般都省略了,指针变量本身保存在缺省存储的区域中。定义时,缺省指针存储的区

33、域,显得简单,并且对初学者更容易理解。,4.6.3 指针变换,一、通用指针格式 由前面的讨论知,通用指针由3个字节组成,第一个字节为数据的存储区域,后两个字节为指针地址,第一个字节的存储区域编码如表4-6所示。,4.6.3 指针变换,一、指针转换指针转换有两种途径,一种是显式的编程转换,另一种是隐式的自动转换。指针的编程转换:(1)通用指针的第一字节,与专用指针的指向数据区属性,二者相互转换;(2)通用指针后两个字节的地址,与专用指针值的转换。指针的隐式自动转换:由编译器在进行编译时自动完成。,4.6.4 C51指针应用,指针在PC机上的C语言中应用很广泛。在单片机中,由于不使用操作系统,指针

34、的应用可以独立于变量,独立地指向所需要访问的存储空间位置。本节通过例子来学习和认识C51指针的这种独立应用性。下面介绍两种利用指针访问存储区的方法。也可以访问函数。,4.6.4 C51指针应用,二、通过指针定义的宏访问存储器1、访问存储器宏的定义用指针定义的、访问存储器宏的格式:#define 宏名(数据类型 volatile 存储区*)0)格式中的数据类型主要为无符号的字符型数、整型;格式中的存储区域主要使用data、idata、pdata、xdata和code类型,不使用bdata存储区类型。,4.6.4 C51指针应用,格式中的关键字“volatile”:“volatile”是单片机中定

35、义的,其含义为:这种变量在程序执行中可被隐含地改变而编译器无法检测到,告知编译器不要做优化处理,使应用者能够得到正确的变量值。volatile的应用:volatile常用于定义寄存器,特别是状态寄存器,因为状态寄存器的值不是程序员设置,而是单片机在运行中CPU设置的。特别说明:“volatile”的含义与教材上表述不太一致,此处表述直观更容易理解。,4.6.4 C51指针应用,2、库函数中访问存储器宏的原型C51编译器提供了两组用指针定义的绝对存储器访问的宏,其原型如下。1)按字节访问存储器的宏:#define CBYTE(unsigned char volatile code*)0)#def

36、ine DBYTE(unsigned char volatile data*)0)#define PBYTE(unsigned char volatile pdata*)0)#define XBYTE(unsigned char volatile xdata*)0),4.6.4 C51指针应用,2)按整型双字节访问存储器的宏:#define CWORD(unsigned int volatile code*)0)#define DWORD(unsigned int volatile data*)0)#define PWORD(unsigned int volatile pdata*)0)#de

37、fine XWORD(unsigned int volatile xdata*)0)无idata型,不能访问片内RAM高128字节区域(0 x800 xff),需要时可以自己定义。这些宏定义原型放在absacc.h文件中,使用时需要用预处理命令把该头文件包含到文件中,形式为:#include。,4.6.4 C51指针应用,3、绝对访问存储器宏的应用使用宏定义访问存储器的形式类似于数组。1)按字节访问存储器宏的形式宏名地址即数组中的下标就是存储器的地址,因此使用起来非常方便。例如:DBYTE0 x30=48;/给片内RAM送数据XBYTE0 x0002=0 x36;/给片外RAM送数据dis_b

38、uf0=CBYTETABLE+5;/从CODE区读取数据,4.6.4 C51指针应用,2)按整型数访问存储器宏的形式宏名下标由于整型数占两个字节,所以下标与地址的关系为:地址=下标2。由于数组中的下标与存储器的地址是倍数关系,使用时要注意。例如:DWORD0 x20=0 x1234;/给0 x40、0 x41送数XWORD0 x0002=0 x5678;/给4、5单元送数通过指针定义的宏访问存储器这种方法,特别适用于访问I/O口。,4.6.4 C51指针应用,一、通过专用指针直接访问存储器使用指针直接访问存储器对PC机是禁止的,但对于单片机来说使用时注意是可以的。使用指针直接访问存储器方法是先

39、定义所需要的指针,给指针赋地址值,然后使用指针访问存储器。例如:unsigned char xdata*xcpt;xcpt=0 x2000;*xcpt=123;/给0 x2000送数xcpt+;*xcpt=234;/给0 x2001送数,4.6.4 C51指针应用,例4-1 编写程序,将单片机片外数据存储器中地址从0 x1000开始20个字节数据,传送到片内数据存储器地址从0 x30开始的区域。程序段如下:unsigned char data i,*dcpt;unsigned char xdata*xcpt;dcpt=0 x30;/给指针赋地址xcpt=0 x1000;for(i=0;i20;

40、i+)*(dcpt+i)=*(xcpt+i);,dcpt和xcpt两个指针变量存储在什么地方?,4.6.4 C51指针应用,例4-2 在数字滤波中有一种叫做“中值滤波”技术,就是对采集的数据按照从大到小或者从小到大进行排序,然后取中间位置的数作为采样值。试编写一函数,对存放在片内数据存储器中,从0 x50开始的21个单元的采样数据,用冒泡法排序进行中值滤波,并把得到的中值数据返回。中值滤波函数如下:unsigned char median_filter()unsigned char data*point,i,j,n,d;,4.6.4 C51指针应用,for(i=0;i20;i+)/外层循环20

41、次point=0 x50;/point指向0 x50处n=20i;/n为内层循环次数for(j=0;jn;j+)/内层循环if(*point*(point+1)/从大到小排d=*point;*point=*(point+1);*(point+1)=d;point+;/指针指向下一个数point=0 x50+10;/指向位于中间的数return*point;/返回得到的中值,4.7 C51的输入/输出,主要内容4.7.1 基本输入/输出函数4.7.2 格式输出函数printf4.7.3 格式输入函数scanf,4.7 C51的输入/输出,C51的输入和输出函数的形式虽然与ANSI C的一样,但实

42、际意义和使用方法都大不一样,因此,有必要专门介绍一下C51的输入/输出函数。在C51的I/O函数库中定义的I/O函数,都是以_getkey和putchar函数为基础。这些I/O函数包括:字符输入/输出函数getchar和putchar,字符串输入/输出函数gets和puts,格式输入/输出函数printf和scanf等。,4.7 C51的输入/输出,C51的输入/输出函数,都是通过单片机的串行接口实现的。在使用这些I/O函数之前,必须先对单片机的串行口、定时器/计数器T1进行初始化。假设单片机的晶振为11.0592MHz,波特率为9600bps,则初始化程序段为:SCON=0 x52;/设置串

43、口方式1收、发TMOD=0 x20;/设置T1以模式2工作TL1=0 xfd;/设置T1低8位初值TH1=0 xfd;/设置T1自动重装初值TR1=1;/开T1,4.7.1 基本输入/输出函数,1、基本输入函数getkeygetkey函数是基本的字符输入函数,原型为char _getkey(void)函数功能:从单片机串行口读入一个字符,如果没有字符输入则等待,返回值为读入的字符,不显示。可重入函数。字符输入函数getchar()功能:与getkey基本相同,唯一的区别:还要从串行口返回字符。,4.7.1 基本输入/输出函数,2基本输出函数putcharputchar函数是基本的字符输出函数,

44、其原型为:char putchar(char)函数功能:是从单片机的串行口输出一个字符,返回值为输出的字符。putchar为可重入函数。,4.7.2 格式输出函数printf,函数功能:通过单片机的串行口输出若干任意类型的数据。格式如下:printf(格式控制,输出参数表)格式控制是用双引号括起来的字符串,也称为转换控制字符串,它包括三种信息:格式说明符普通字符转义字符。,4.7.1 格式输出函数printf,1)格式说明符:由百分号“%”和格式字符组成,其作用是指明输出数据的格式,如%d、%c、%s等,详细情况见表4-3。2)普通字符:这些字符按原样输出,主要用来输出一些提示信息。3)转义字

45、符:由“”和字母或字符组成,它的作用是输出特定的控制符,如转义字符n的含义是输出换行,详细情况见表4-4。,4.7.1 格式输出函数printf,4.7.1 格式输出函数printf,用printf函数输出例子(假设y已定义过,也赋值过):printf(“x=%d”,36);/从串行口输出x=36printf(“y=%d”,y);/从串行口输出y=y的值printf(“c1=%c,c2=%c”,A,B);/从串行口输出c1=A,c2=Bprintf(“%sn”,“OK,Send data begin!”);/从串行口输出OK,Send data begin!和n,4.7.2 格式输入函数sca

46、nf,scanf函数的功能:通过单片机串行口实现各种数据输入。函数格式如下:scanf(格式控制,地址列表)格式控制格式控制与printf函数的类似,也是用双引号括起来的一些字符,包括三种信息:格式说明符、普通字符和空白字符。1)格式说明符:由百分号“%”和格式字符组成,其作用是指明输入数据的格式,见表4-5。,4.7.2 格式输入函数scanf,2)普通字符:在输入时,要求这些字符按原样输入。3)空白字符:包括空格、制表符和换行符等,这些字符在输入时被忽略。地址列表:是由若干个地址组成,它可以是指针变量、变量地址(取地址运算符“&”加变量)、数组地址(数组名)或字符串地址(字符串名)等。,4

47、.7.2 格式输入函数scanf,用scanf函数输入例子(假设x、y、z、c1、c2是定义过的变量,str1是定义过的指针):scanf(“%d”,&x);scanf(“%d%d”,&y,&z);scanf(“%c%c”,&c1,&c2);scanf(“%s”,str1);在实际的串行通信中,传输的数据多数是字符型和字符串,以字符串居多,往往把数字型数据转换成字符串传输。,4.7.2 格式输入函数scanf,例4-3 有一单片机时钟系统,为了演示输出函数putchar和输入函数getkey的应用,编写程序,用串行口方式1自发自收,每一秒钟从串行口发送一次时间数据的时、分、秒,从串行口接收到数

48、据后,送给6位数码管显示。设晶振频率为11.0592MHz,波特率为9600bps。不用编写时钟计时函数和数码管显示函数。,4.7.2 格式输入函数scanf,#include/包含头文件#include/包含I/O函数库unsigned char data t13;/存放原始的时分秒unsigned char data dis_buf6;/数码管显示void main(void)unsigned char data t23;/放接收的时间unsigned char data sec0=61;/秒备份unsigned char data i;,4.7.2 格式输入函数scanf,SCON=0

49、x52;/串行口初始化TMOD=0 x20;/设置定时器工作模式TH1=0 xfd;/设置T1重装的初值TR1=1;/开T1运行while(1)if(sec0!=t12)/判断秒是否已经改变 putchar(t1i);t2i+=_getkey();,4.7.2 格式输入函数scanf,if(i2)dis_buf0=t20/10;dis_buf1=t20%10;dis_buf2=t21/10;dis_buf3=t21%10;dis_buf4=t22/10;dis_buf5=t22%10;i=0;sec0=t12;/更新秒备份 display();/调用数码管扫描显示函数,4.8 C51函数的定义

50、,主要内容4.8.1 C51函数的定义4.8.2 C51中断函数的定义,C51函数的定义与ANSI C相似,但有更多的属性要求。本节先讨论函数的一般定义,然后专门给出中断函数的定义,因为中断函数有其特殊性。,4.8.1 C51函数的定义,在C51中,函数的定义与ANSI C中是相同的。唯一不同的就是在函数的后面需要带上若干个C51的专用关键字。C51函数定义的一般格式如下:返回类型 函数名(形参表)函数模式 reentrant interrupt m using n局部变量定义执行语句,4.8.1 C51函数的定义,各属性含义如下:函数模式:也就是编译模式、存储模式,可以为small、comp

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

当前位置:首页 > 建筑/施工/环境 > 农业报告


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号