单片机C语言C51教程.docx

上传人:无*** 文档编号:87078346 上传时间:2023-04-16 格式:DOCX 页数:43 大小:482.40KB
返回 下载 相关 举报
单片机C语言C51教程.docx_第1页
第1页 / 共43页
单片机C语言C51教程.docx_第2页
第2页 / 共43页
点击查看更多>>
资源描述

《单片机C语言C51教程.docx》由会员分享,可在线阅读,更多相关《单片机C语言C51教程.docx(43页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、第四课数据类型先来简单说说c语言的标识符和关键字。标识符是用来标识源程序中某个对象的名字的,这些对象可以是语句、数据类型、函数、变量、数组等等。C语言是大小字敏感的一种高级语言,如果我们要定义一个定时器1,可以写做“Timerl,如果程序中有T1MER1”,那么这两个是完全不同定义的标识符。标识符由字符串,数字和下划线等组成,注意的是第一个字符必须是字母或下划线,如【Timer”是错误的,编译时便会有错误提示。有些编译系统专用的标识符是以下划线开头,所以一般不要以下划线开头命名标识符。标识符在命名时应当简单,含义清晰,这样有助于阅读理解程序。在C51编译器中,只支持标识符的前32位为有效标识,

2、一般情况下也足够用了,除非你要写天书:P。关键字则是编程语言保留的特殊标识符,它们具有固定名称和含义,在程序编写中不允许标识符与关键字相同。在KEIL uVision2中的关键字除了有ANSI C标准的32个关键字外还根据51单片机的特点扩展了相关的关键字。其实在KEIL uVision2的文本编辑器中编写C 程序,系统可以把保留字以不同颜色显示,缺省颜色为天蓝色。先看表41,表中列出了 KEILuVision2 c51编译器所支持的数据类型。在标准C语言中基本的数据类型为char,int,short,long,float和double,而在C51编译器中int和short相同, float和

3、double相同,这里就不列出说明了。下面来看看它们的具体定义:数据类型长度值域unsigned char单字节0-255signed char单字节128+127unsigned int双字节065535signed int双字节-32768+32767unsigned long四字节。4294967295signed long四字节-2147483648+2147483647float四字节 L175494E.383.402823E+38*13字节对象的地址bit位0或1sfr单字节0-255sfrl6双字节0-65535sbit位0或1表4-1 KEILuVision2 c51编译器所支

4、持的数据类型1. char字符类型char类型的长度是一个字节,通常用于定义处理字符数据的变量或常量。分无符号字符类型 unsigned char和有符号字符类型signed char,默认值为signed char类型。unsigned char类型用字节中所有的位来表示数值,所可以表达的数值范围是0255。signed char类型用字节中最高位字节表示数据的符号,0表示正数,1”表示负数,负数用补码表示。所能表示的数值范围是-128+127。unsigned char常用于处理ASCII字符或用于处理小于或等于255的整型数。*正数的补码与原码相同,负二进制数的补码等于它的绝对值按位取反

5、后加k2. int整型int整型长度为两个字节,用于存放一个双字节数据。分有符号int整型数signed int和无符号整型数unsigned int.默认值为signed int类型。signed int表示的数值范围是-32768+32767,字节中最高位表示数据的符号,0”表示正数,1”表示负数。unsigned int表示的数值范围是065535。好了,先停,下吧,我们来写个小程序看看unsigned char和unsigned int用于延时的不同效果,说明它们的长度是不同的,呵,尽管它并没有实际的应用意义,这里我们学习它们的用法就行。依旧用我们上一课的最小化系统做实验,不过要加多一

6、个电阻和LED,如图4一1。实验中用D1的点亮表明正在用unsigned int数值延时,用D2点亮表明正在用unsigned char 数值延时。R2 560VCCO31匚二I1.24MI z30pF -9S.2K10uFR3 560D2151417C319185_XT工P1.0PO.O(ADO)Pl.lPO.1(AD1)Pl.2P0.2(AD2)Pl .3P0.3(AD3)Pl.4P0.4(ATM)Pl.5PO.5(AD5)Pl.6P0.6(AD6)Pl.7P0.7(AD7)INT1(P3.3)P2.0(A8)INT0(P3.2)P2.1(A9)P2.2(A10)T1(P3.5)P2.3(

7、AU)T0(P3.4)P2.4(A12)P2.5(A13)EAATP2.6(A14)P2.7(A15)XTAL1XTAL2VCCGNDRESETRXD(P3.0)TXD(P3.1)RD(P3.7)ALEPROGWR(P3.6)PSEN39383740 2010 亘 30 29212223 至 252627283 G343332OVCCGNDOVCC图4-1第4课实验用电路我们把这个项目称为TwoLED,实验程序如下:#include 预处理命令void main(void)主函数名(unsigned int a;定义变量 a 为 unsigned int 类型unsigned char b;定

8、义变量 b 为 unsigned char 类型 do/do while组成循环for (a=0; a65535; a+)Pl_0=0;/65535次设P1.0口为低电平,点亮LEDPl_0=l;设P1.0口为高电平,熄灭LEDfor (a=0; a30000; a+);空循环for (b=0; b255; b+)Pl_l=O;/255次设P1.1口为低电平,点亮LEDPl_l =1;设P1.1口为高电平,熄灭LEDfor (a=0; a30000; a+);空循环while(l);)同样编译烧写,上电运行您就可以看到结果了。很明显D1点亮的时间长于D2点亮的时间。程序中的循环延时时间并不是很

9、好确定,并不太适合要求精确延时的场合,关于这方面我们以后也会做讨论。这里必须要讲的是,当定义一个变量为特定的数据类型时,在程序使用该变量不应使它的值超过数据类型的值域。如本例中的变量b不能赋超出。255的值,如for (b=0; b255; b+)改为for (b=0; b256; b+),编译是可以通过的,但运行时就会有问题出现,就是说b的值永远都是小于256的,所以无法跳出循环执行下一句Pl_1=1,从而造成死循环。同理a的值不应超出065535。大家可以烧片看看实验的运行结果,同样软件仿真也是可以看到结果的。3. long长整型long长整型长度为四个字节,用于存放一个四字节数据。分有符

10、号long长整型signed long 和无符号长整型unsigned long,默认值为signed long类型。signed int表示的数值范围是-2147483648+2147483647,字节中最高位表示数据的符号,0”表示正数,T表示负数。 unsigned long表示的数值范围是04294967295。4. float浮点型float浮点型在十进制中具有7位有效数字,是符合IEEE-754标准的单精度浮点型数据,占用四个字节。因浮点数的结构较复杂在以后的章节中再做详细的讨论。5.*指针型指针型本身就是一个变量,在这个变量中存放的指向另一个数据的地址。这个指针变量要占据一定的内

11、存单元,对不同的处理器长度也不尽相同,在C51中它的长度一般为13个字节。指针变量也具有类型,在以后的课程中有专门一课做探讨,这里就不多说了。6. bit位标量bit位标量是C51编译器的一种扩充数据类型,利用它可定义一个位标量,但不能定义位指针,也不能定义位数组。它的值是一个二进制位,不是。就是1,类似一些高级语言中的 Boolean 类型中的 True 和 False。7. sfr特殊功能寄存器sfr也是一种扩充数据类型,点用一个内存单元,值域为0255。利用它可以访问51单片机内部的所有特殊功能寄存器。如用sfrP1=0x90这一句定P1为P1端口在片内的寄存器,在后面的语句中我们用以用

12、P1=255(对P1端口的所有引脚置高电平)之类的语句来操作特殊功能寄存器。8. sfrl616位特殊功能寄存器sfrl6占用两个内存单元,值域为065535。sfrl6和sfr一样用于操作特殊功能寄存器,所不同的是它用于操作占两个字节的寄存器,好定时器T0和T1。9. sbit可录址位sbit同位是C51中的种扩充数据类型,利用它可以访问芯片内部的RAM中的可寻址位或特殊功能寄存器中的可寻址位。如先前我们定义了sfrPl =0x90;因P1端口的寄存器是可位寻址的,所以我们可以定义sbit Pl_l = Pl *1;P1_1为 Pl 中的 Pl.l 弓I脚同样我们可以用Pl.l的地址去写,如

13、sbit Pl_l =0x91;这样我们在以后的程序语句中就可以用Pl来对P1.1引脚进行读写操作了。通常这些可以宜接使用系统提供的预处理文件,里面已定义好各特殊功能寄存器的简单名字,直接引用可以省去一点时间,我自己是一直用的。当然您也可以自己写自己的定义文件,用您认为好记的名字。关于数据类型转换等相关操作在后面的课程或程序实例中将有所提及。大家可以用所讲到的数据类型改写一下这课的实例程序,加深对各类型的认识。附录附录一 C51中的关键字关键字用途说明auto存储种类说明用以说明局部变量,缺省值为此break程序语句退出最内层循环case程序语句Switch语句中的选择项char数据类型说明单

14、字节整型数或字符型数据const存储类型说明在程序执行过程中不可更改的常量值continue程序语句转向下一次循环default程序语句Switch语句中的失败选择项do程序语句构成do. while循环结构double数据类型说明双精度浮点数else程序语句构成if. else选择结构enum数据类型说明枚举extern存储种类说明在其他程序模块中说明了的全局变JS.里flost数据类型说明单精度浮点数for程序语句构成for循环结构goto程序语句构成goto转移结构if程序语句构成if. else选择结构int数据类型说明基本整型数long数据类型说明长整型数register存储种类说明

15、使用CPU内部寄存的变量return程序语句函数返回short数据类型说明短整型数signed数据类型说明有符号数,二进制数据的最高位为符号位sizeof运算符计算表达式或数据类型的字节数static存储种类说明静态变量struct数据类型说明结构类型数据swicth程序语句构成switch选择结构typedef数据类型说明重新进行数据类型定义union数据类型说明联合类型数据unsigned数据类型说明无符号数数据void数据类型说明无类型数据volatile数据类型说明该变量在程序执行中可被隐含地改变while程序语句构成while和do. while循环结构附表1-1 ANS IC标准关

16、键字关键字用途说明bit位标量声明声明一个位标量或位类型的函数sbi t位标量声明声明一个可位寻址变量Sfr特殊功能寄存器声明声明一个特殊功能寄存器Sfrl6特殊功能寄存器声明声明一个16位的特殊功能寄存器data存储器类型说明直接寻址的内部数据存储器bdata存储器类型说明可位寻址的内部数据存储器idata存储器类型说明间接寻址的内部数据存储器pdata存储器类型说明分页寻址的外部数据存储器xdata存储器类型说明外部数据存储器code存储器类型说明程序存储器interrupt中断函数说明定义一个中断函数reentrant再入函数说明定义一个再入函数using寄存器组定义定义芯片的工作寄存器

17、附表1-2 C51编译器的扩展关键字附录二AT89c51特殊功能寄存器列表(适用于同一架构的芯片)符号地址注释*ACCE0H累加器*BF0H乘法寄存器*PSWDOH程序状态字SP81H堆栈指针DPL82H数据存储器指针低8位DPH83H数据存储器指针高8位*IEA8H中断允许控制器*IPD8H中断优先控制器*P080H端口0*P190H端口1*P2AOH端口2*P3BOH端口3PCON87H电源控制及波特率选择*SCON98H串行口控制器SBUF99H串行数据缓冲器*TCON88H定时器控制TMOD89H定时器方式选择TLO8AH定时器0低8位TL18BH定时器1低8位THO8CH定时器0低8

18、位TH18DH定时器1高8位带*号的特殊功能寄存器都是可以位寻址的寄存器第五课常量上一节我们学习了 KEILC51编译器所支持的数据类型。而这些数据类型又是怎么用在常量和变量的定义中的呢?又有什么要注意的吗?下面就来看看吧。晕!你还区分不清楚什么是常量,什么是变量。常量是在程序运行过程中不能改变值的量,而变量是可以在程序运行过程中不断变化的量。变量的定义可以使用所有C51编译器支持的数据类型,而常量的数据类型只有整型、浮点型、字符型、字符串型和位标量。这一节我们学习常量定义和用法,而卜.一节则学习变量。常量的数据类型说明是这样的1 .整型常量可以表示为十进制如123,0,-89等。十六进制则以

19、Ox开头如0x34,-0x3B等。长整型就在数字后面加字母 L,如104L,034L,0xF340等。2 .浮点型常量可分为:进制和指数表示形式。十进制由数字和小数点组成,如0.888,3345.345,00等,整数或小数部分为0,可以省略但必须有小数点。指数表示形式为仕数字.数字e数字,口中的内容为可选项,其中内容根据具体情况可有可无,但其余部分必须有,如125e3,7e9,-3.0e-3.3 .字符型常量是单引号内的字符,如,等,不可以显示的控制字符,可以在该字符前面加一个反斜杠组成专用转义字符。常用转义字符表请看表51。4 .字符串型常量由双引号内的字符组成,如“test,“OK”等。当

20、引号内的没有字符时,为空字符串。在使用特殊字符时同样要使用转义字符如双引号。在C中字符串常量是做为字符类型数组来处理的,在存储字符串时系统会在字符串尾部加上o转义字符以作为该字符串的结束符字符串常量A和字符常量A是不同的,前者在存储时多占用个字节的字间。5.位标量,它的值是一个二进制。转义字符含义ASCII 码(16/10进制)o空字符(NULL)00H/0n换行符(LF)0AH/10r回车符(CR)0DH/13t水平制表符(HT)09H/9b退格符(BS)08H/8f换页符(FF)0CH/12V单引号27H/39双引号22H/34反斜杠5CH/92表51常用转义字符表常量可用在不必改变值的场

21、合,如固定的数据表,字库等。常量的定义方式有几种,下面来加以说明。#difine False 0x0;/用预定义语句可以定义常量#difineTrueOxl;这里定义 False 为 O.True 为1在程序中用到False编译时自动用0替换,同理True替换为1unsigned int code a=100;这一句用code把a定义在程序存储器中并赋值const unsigned int c=100;用const定义c为无符号int常量并赋值以上两句它们的值都保存在程序存储器中,而程序存储器在运行中是不允许被修改的,所以如果在这两句后面用了类似a=110, a+这样的赋值语句,编译时将会出错

22、。说了一通还不如写个程序来实验一下吧。写什么程序呢?跑马灯!对,就写这个简单易懂的吧,这个也好说明典型的常鼠用法。先来看看电路图吧。它是在我们上一课的实验电路的基础上增加6个LED组成的,也就是用P1口的全部引脚分别驱动一个LED,电路如图51所示.新建个RunLED的项目,主:程序如下:include 预处理文件里面定义了特殊寄存器的名称如PI 口定义为PI void main(void)(定义花样数据cons (unsigned char design32=OxFF,0xFE,0xFD,()xFB,OxF7,0xEF,0xDF,0x BF,0x7F,0x7F,0xBF,0xDF,0xEF,

23、0xF7,0xFB,0xFD,0xFE,0xFF,0xFF,0x FE,0xFC,0xF8,0x F0,0x E0,0xC0,0x 80,0x0,0xE7,0xDB.0xBD,0x7E,0xFF);unsigned int a;定义循环用的变量unsigned charb;在C51编程中因内存有限尽可能注意变量类型的使用尽可能使用少字节的类型,在大型的程序中很受用dofor(b=0; b32; b+)(for(a=0; a30000; a+);延时一段时间Pl =(iesignb;读已定义的花样数据并写花样数据到P1口)while(l);程序中的花样数据可以自以去定义,因这里我们的LED要AT

24、89c51的Pl引脚为低电平才会点亮,所以我们要向P1口的各引脚写数据。对应连接的LED才会被点亮,P1口的八个引脚刚好时应P1口特殊寄存器的八个二进位,如向P1定数据OxFE,转成二进制就是11111110撮低位D0为0这里PL0引脚输出低电平,LED1被点亮。如此类推,大家不难算出自己想要做的效果了。大家编译烧写看看,效果就出来,显示的速度您可以根据需要调整延时a的值,不要超过变量类型的值域就很行了.哦,您还没有实验板?那如何可以知道程序运行的结果呢?呵,不用急,这就来说说用KEILuVision2的软件仿真来调试IO 口输HI输入程序。INT1(P33)INTO(P3J)T1(P35)T

25、O(P3.4)EA/VPXTAL1XTAL2RESETRD(P3.7)WR(P3j6)VCCP1DPl.1P1JP13Pl.4P15P16Pl.7POD(ADO) PO.l(ADl) POR ADZ) P03(AD3) P0.4(AD4) P05(AD5) P06(AD6) P0.7(AD7)P2J0(A8) P2.1(A9)P22(A10) P23(A11) P2.4(A12) P25(A13) P2j6(A14) P2.7(A15)VCC GNDRXD(P3J0) TXD(P3.1) ALE/PROG PSEN39383736353432212224252627284020JOIT3029

26、OVCCGND图5一1八路跑马灯电路编译运行上面的程序,然后按外部设备菜单Peripherals I/O Ports Portl就打开Port 1的调试窗口了,如图53中的2。这时程序运行了,但我们并不能在Poul调试窗口上看到有会什么效果,这时我们可以用鼠标左击图53中1旁边绿色的方条,点一下就有一个小红方格在点一下又没有了,哪一句语句前有小方格程序运行到那一句时就停止了,就是设置调试断点,同样图52中的1也是同样功能,分别是增加/移除断点、移除所有断点、允许/禁止断点、禁止所有断点,菜单也有样的功能,另外菜单中还有Breakpoints可打开断点设置窗口它的功能更强大,不过我们这里先不用它

27、。我们?quol;Pl=designb;“这一句设置一个断点这时程序运行到这里就停住了,再留意一下Portl调试窗口,再按图5-2中的2的运行健,程序又运行到设置断点的地方停住了,这时Portl调试窗口的状态又不同了。也就是说Portl调试窗口模拟了 P1的电平状态,打勾为高电平,不打勾则为低电平,窗口中P1为P1寄存器的状态,Pins为引脚的状态,注意的是如果是读引脚值必须把引脚对应的寄存器置1才能正确读取。图5-2中2旁边的样的按钮分别为单步入,步越,步出和执行到当前行。图中3为显示下一句将要执行的语句。图5-3中的3是Walches窗口可查看各变量的当前值,数组和字串是显示其头一个地址,

28、如本例中的design数组是保存在code存储区的首地址为D:0x08,可以在图中4 Memory 存储器查看窗口中的Address地址中打入D:0x08就可以查看到design各数据和存放地址了。如愕雎Vision2没有显示这些窗口,可以在View菜单中打开在图5-2中3后面一栏的查看窗口快捷栏中打开。联:RunLED - WisionZFile Edit View Project Debug Peripherals Tools SVCS Window Help置以口价x舱唱|。之|小隼力为%叁聃图三触值|昌|阿|同国3命眄购造|吗P的a供1(以中超达|俄睇b*国/7图52调试用快捷菜单栏尽

29、可能使用少字节的类型,在大型的程序中很受用dofor (b=0; b35; b+)E-,.for(a=0; a50000; a+);/延时一段时间Pl = designb;/读已定义的花样数据并写花样数据到Pl口while(l);=| RunLED. cNameValuekddress:亩Idesigna-b0xC3500x10|D:0x08 48 0 4 4 40 8 0 2 24 0 8 8 20 8 0 142 0 0 0 10 4 10 81 o o 1 10 2 2 0 80 0 0 2 20 14 0 4图5-3各调试窗口第六课变量上课所提到变量就是种在程序执行过程中其值能不断变化

30、的量。要在程序中使用变量必须先用标识符作为变量名,并指出所用的数据类型和存储模式,这样编译系统才能为变量分配相应的存储空间。定义一个变量的格式如卜.:存储种类数据类型存储器类型变量名表在定义格式中除了数据类型和变量名表是必要的,其它都是可选项。存储种类有四种:自动(auto),夕邰(extern),静态(static)和寄存器(register),缺省类型为自动(auto)。这些存储种类的具体含义和用法,将在第七课变量的存储中进一步进行学习。而这里的数据类型则是和我们在第四课中学习到的名种数据类型的定义是一样的。说明了一个变最的数据类型后,还可选择说明该变量的存储器类型。存储器类型的说明就是指

31、定该变量在C51硬件系统中所使用的存储区域,并在编译时准确的定位。表61中是KEILuVision2所能认别的存储器类型。注意的是在AT89c51芯片中RAM只有低128位,位于80H到FFH的高128位则在52芯片中才有用,并和特殊寄存器地址而叠。特殊寄存器(SFR)的地址表请看附录二AT89c51特殊功能寄存器列表存储器类型说明data直接访问内部数据存储器(128字节),访问速度最快bdata可位寻址内部数据存储器(16字节),允许位与字节混合访问idata间接访问内部数据存储器(256字节),允许访问全部内部地址pdata分页访问外部数据存储器(256字节),用MOVX Ri指令访问x

32、data外部数据存储器(64KB),用MOVX DPTR指令访问code程序存储器(64KB),用MOVC A+DPTR指令访问表61存储器类型如果省略存储器类型,系统则会按编译模式SMALL,COMPACT或LARGE所规定的默认存储器类型去指定变量的存储区域。无论什么存储模式都可以声明变量在任何的8051存储区范围,然而把最常用的命令如循环计数器和队列索引放在内部数据区可以显著的提高系统性能。还有要指出的就是变最的存储种类与存储器类型是完全无关的。SMALL存储模式把所有函数变量和局部数据段放在8051系统的内部数据存储区这使访问数据非常快,但SMALL 存储模式的地址空间受限。在写小型的

33、应用程序时,变量和数据放在data内部数据存储器中是很好的因为访问速度快,但在较大的应用程序中data区最好只存放小的变量、数据或常用的变量(如循环计数、数据索引),而大的数据则放置在别的存储区域。COMPACT存储模式中所有的函数和程序变量和局部数据段定位在8051系统的外部数据存储区。外部数据存储区可有最多256字节(页),在本模式中外部数据存储M的短地址用RO/R1。LARGE存储模式所有函数和过程的变量和局部数据段都定位在8051系统的外部数据区外部数据区最多可有64KB,这要求用DPTR数据指针访问数据。之前提到简单提到sfr,sfrl6,sbit定义变量的方法,下面我们再来仔细看看

34、。sfr和sfrl6可以直接对51单片机的特殊寄存器进行定义,定义方法如下:sfr特殊功能寄存器名=特殊功能寄存器地址常数;sfr16特殊功能寄存器名=特殊功能寄存器地址常数;我们可以这样定义AT89c51的Pl Usfr Pl =0x90;定义 Pl I/O d,其地址90Hsfr关键定后面是一个要定义的名字,可任意选取,但要符合标识符的命名规则,名字最好有定的含义如P1口可以用P1为名,这样程序会变的好读好多。等号后面必须是常数,不允许有带运算符的表达式,而且该常数必须在特殊功能寄存器的地址范围之内(80H FFH),具体可查看附录中的相关表。sfr是定义8位的特殊功能寄存器而sfrl6则

35、是用来定义16位特殊功能寄存器,如8052的T2定时器,可以定义为:sfr 16 T2= OxCC;这里定义8052定时器2,地址为 T2L=CCH,T2H=CDH用sfrl6定义16位特殊功能寄存器时,等号后面是它的低位地址,高位地址一定要位于物理低位地址之上。注意的是不能用于定时器0和1的定义。sbit可定义可位寻址对象.如访问特殊功能寄存器中的某位。其实这样应用是经常耍用的如要访问P1口中的第2个引脚P1.1。我们可以照以下的方法去定义:(I )sbit位变量名=位地址sbitPl_l =0x91;这样是把位的绝对地址赋给位变量。同sfr 样sbit的位地址必须位于80H-FFH之间。(

36、2)Sbit位变量名=特殊功能寄存器名人位位置sftPl =0x90;sbit Pl=Pl 1;先定义一个特殊功能寄存器名再指定位变量名所在的位置当可寻址位位于特殊功能寄存器中时可采用这种方法(3)sbit位变量名=字节地址入位位置sbit Pl_l =0x90 A 1;这种方法其实和2是一样的,只是把特殊功能寄存器的位址宜接用常数表示。在C51存储器类型中提供有个bdata的存储器类型,这个是指可位寻址的数据存储器,位于单片机的可位寻址区中,可以将要求可位录址的数据定义为bdata,如:unsigned char bdata ib;在可位录址区定义ucsigned char类型的变量ibin

37、t bdata ab;在可位寻址区定义数组ab2,这些也称为可寻址位对象sbit ib7=ib用关键字sbit定义位变量来独立访问可寻址位对象的其中位sbitab!2=ablA12;操作符后面的位位置的最大值取决于指定的基址类型,chaid7,int(M5,longO-31。下面我们用上一课的电路来实践一下这一课的知识。同样是做一下简单的跑马灯实验,项目名为RunLED2。程序如下: sfrPI =0x90;这里没有使用预定义文件,sbitPl_0= Pl八0;而是自己定义特殊寄存器sbit PL7=0x907;之前我们使用的预定义文件其实就是这个作用sbitPl=0x91;这里分别定义P1端

38、口和P10,P1LP17引脚void main(void)(unsigned int a;unsigned char b;dofor(a=0;a5(X)(X);a+)Pl_0=0;点亮 Pl_0for (a=0:a50000;a+)Pl_7=0;点亮 Pl_7for (b=0;b255;b+)(for(a=0;a10000;a+)Pl =b;用b的值来做跑马灯的花样(Pl =255;熄灭 Pl 上的 LEDfor(b=0;b255;b+)for (a=0;al 0000;a+)P 1_1闪烁Pl_l =0;for (a=0;a10000;a+)Pl_l =1; while ;第七课运算符和表达

39、式(1)作者:明浩出处:磁动力:作室pnzwzw(ID23)上课到这一课相隔了好长一段时间,这些日子里收到不少网友的来信支持和鼓励,要求尽快完成余卜的部分。出门在外的人不得不先为吃饭而努力,似乎这也成为我的借口,以后每晚抽空打些吧这样大家也就可以不用隔太久就能看到些新东西。或许我的笔记并不是很正确,但我尽量的保证每课的实验都会亲自做次,包括硬件的部分,已求不会误人子弟。随着访问最不断的增加,网站已启用了 的国际域名,在这里我感谢各位一直支持磁动力工作室的朋友,更要感激身在远方一直默默支持我的女友。明浩2003-7-14晚呵,费话少说了。上两课说了常量和变量,先来补充个用以重新定义数据类型的的语

40、句吧。这个语句就是typedef,这是个很好用的语句,但我自己却不常用它,通常我定义变量的数据类型时都是使用标准的关键字,这样别人可以很方便的研读你的程序。如果你是个DELPHI编程爱好者或是程序员,你对变量的定义也许习惯了 DELPHI的关键字,如int 类型常会用关键字Integer来定义,在用C51时你还想用回这个的话,你可以这样写:typedef int integer;integer a,b;这两句在编译时,其实是先把integer定义为int,在以后的语句中遇到integer就用int置换,integer就等于 int,所以a,b 也就被定义为int。typedef不能直接用来定义

41、变量,它只是对已有的数据类型作个名字上的置换,并不是产生个新的数据类型。下面两句就是一个错误的例子:typedef int integer;integer =100;使用typedef可以有方便程序的移植和简化较长的数据类型定义。用typedef还可以定义结构类型,这点在后面详细解说结构类型时再并说明。typedef的语法是typedef已有的数据类型新的数据类型名运算符就是完成某种特定运算的符号。运算符按其表达式中与运算符的关系可分为单目运算符,双目运算符和三目运算符。单目就是指需要有一个运算对象,双口就要求有两个运算对象,三目则要三个运算对象。表达式则是由运算及运算对象所组成的具有特定含义

42、的式子。C是一种表达式语言,表达式后面加;”号就构成了一个表达式语句。赋值运算符对于=这个符号大家不会陌生的,在C中它的功能是给变量赋值,称之为赋值运算符。它的作用不用多说大家也明白,就是但数据赋给变量。如,x=10;由此可见利用赋值运算符将一个变量与一个表达式连接起来的式子为赋值表达式,在表达式后面加“;”便构成了赋值语句。使用=的赋值语句格式如下:变量=表达式;示例如下a = OxFF;/将常数I-六进制数FF赋于变量ab = c =33;/同时赋值给变量b,cd = e;将变量e的值赋于变量df=a+b;将变量a+b的值赋于变量f由上.面的例子可以知道赋值语句的意义就是先计算出=”右边的

43、表达式的值,然后将得到的值赋给左边的变量。而且右边的表达式可以是一个赋值表达式。在一些朋友的来信中会出现=与=这两个符号混淆的错误原码,问为何编译报错,往往就是错在if (a=x)之类的语句中,错将=用为符号是用来进行相等关系运算。算术,增减量运算符对于a+b,a/b这样的表达式大家都很熟悉,用在C语言中,+,/,就是算术运算符。C51中的算术运算符有如下几个,其中只有取正值和取负值运算符是单目运算符,其它则都是双目运算符:+加或取正值运算符-减或取负值运算符*乘运算符/除运算符%取余运算符算术表达式的形式:表达式1算术运算符表达式2如:a+b*(10-a),(x+9)/(y-a)除法运算符和

44、般的算术运算规则有所不同,如是两浮点数相除,其结果为浮点数,如10.0/20.0所得值为0.5,而两个整数相除时,所得值就是整数,如7/3,值为2。像别的语言样C的运算符与有优先级和结合性,同样可用用括号()”来改变优先级。这些和我们小时候学的数学几乎是一样的,我也不必过多的说明了。:(还有这么多运算符呀!暂时停一停吧,我们先来做一个实验吧.学习运算符和另外一些知识时,我们还是给我们的实验板加个串行接口吧。借助电脑转件直观的看单片机的输出结果,以后我还会用一些简单的实例讲解单片机和PC 串口通讯的简单应用利编程。如果你用的是成品实验板或仿真器,那你就可以跳过这一段了。在制作电路前我们先来看看要用的MAX232,这里我们不去具体讨论它,只要知道它是TTL和RS232电平相互转换的芯片和基本的引脚接线功能就行了。通常我会用两个小功率晶体管加少量的电路去杵换MAX232,可以省点,效果也不错(如有兴趣可以查看网站中的相关资料)。下图就是MAX232的基本接线图。在上两课的电路的基础上按图7-3加上MAX232就可以了

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

当前位置:首页 > 教育专区 > 教案示例

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

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com