第一章 C51基本语法课件

上传人:我*** 文档编号:138893140 上传时间:2020-07-18 格式:PPT 页数:50 大小:91.50KB
返回 下载 相关 举报
第一章 C51基本语法课件_第1页
第1页 / 共50页
第一章 C51基本语法课件_第2页
第2页 / 共50页
第一章 C51基本语法课件_第3页
第3页 / 共50页
第一章 C51基本语法课件_第4页
第4页 / 共50页
第一章 C51基本语法课件_第5页
第5页 / 共50页
点击查看更多>>
资源描述

《第一章 C51基本语法课件》由会员分享,可在线阅读,更多相关《第一章 C51基本语法课件(50页珍藏版)》请在金锄头文库上搜索。

1、21世纪高等学校精品教材,单片机接口技术(C51版) 张道德 编著 杨光友 主审 中国水利水电出版社,单片机接口技术(C51版),第一章 C51基本语法,内容概述,数据类型和运算符、表达式是是C51语言程序设计的最基础知识,C51语言把数据分成了多种数据类型,并提供了丰富的运算对数据进行处理。本章对C51语言的基本数据类型、常量变量、运算符及表达式等进行详细介绍。,教学目标,1掌握数据类型的概念,了解C51语言能够处理的数据类型。 2掌握常量的概念,掌握各种类型常量的特点及表示形式。 3掌握变量的概念,了解int、float、char型变量的特点,掌握这三种类型变量的定义、赋值和使用方法。理解

2、C51中变量的存储和编译模式的关系,掌握单片机片内资源的访问方法。 4了解C51语言的基本运算符及其特点,掌握运算符的优先级和结合性的概念。 5了解算术运算表达式、关系表达式及逻辑表达式的特点,熟练进行表达式计算,能熟练进行实际问题的表达式描述。 6熟悉自增、自减运算的特点,掌握赋值运算,了解逗号运算符和逗号表达式。 7掌握数据类型转换的概念,能进行基本的数据类型转换。,11 C51基本数据类型,具有一定格式的数字或数值叫做数据,数据的不同格式叫作数据类型。任何程序设计都离不开数据的处理。 C5l的数据类型有位型(bit)、无符号字符(unsigned char)、有符号字符(signed c

3、har)、无符号整型(unsigned int)、有符号整型(signed int)、无符号长型(unsigned long)、有符号长型(signed long)、浮点(float)和指针类型等。其中short与long属整型数据、 float与 double型属浮点型数据。,当程序中出现表达式或变量赋值运算时,若运算对象的数据类型不一致,数据类型可以自动进行转换,转换按以下优先级别自动进行: bit char int long float unsigned signed,12 常量与变量,121 常量 在程序运行中其值不能改变的量称为常量。 1整型常量。可以表示为十进制如123,0,-8等

4、。十六进制则以0 x开头如0 x34。长整型就在数字后面加字母L,如10L, 0 xF340L等。 2浮点型常量。分为十进制和指数表示形式。十进制由数字和小数点组成,如0.888,3345.345,0.0等,整数或小数部分为0时可以省略0但必须有小数点。指数表示形式为: 数字.数字e数字 中的内容为可选项,其中内容根据具体情况可有可无,但其余部分必须有,如123e3,5e6,-1.0e-3。而e3,5e4.0则是非法的表示形式。 3字符型常量是单引号内的字符,如a,d等。 4字符串型常量由双引号内的字符组成,如 hello,english等。当引号内的没有字符时,为空字符串。,用标识符代表的常

5、量称为符号常量。 例如:在指令“ #define PI 3.1415926”后,符号常量PI即代表圆周率3.1415926。,1.2.2 变量 1.2.2.1变量类型 在程序运行中,其值可以改变的量称为变量 一个变量主要由两部分构成:一个是变量名,一个是变量值。 每个变量都有一个变量名,在内存中占据一定的存储单元(地址),并在该内存单元中存放该变量的值。,C51支持的变量通常有如下类型: 位变量(bit)位变量的值可以是1(true)或0(false)。与805l硬件特性操作有关的位变量必须定位在8051CPU片内存储区(RAM)的可位寻址空间中。 字符变量(char)字符变量的长度为l by

6、te,即8位。C51编译器默认的字符型变量为无符号型(unsigned char)。负数在计算机中存储时一般用补码表示。 整型变量(int)整型变量的长度为16位。8051系列CPU将整型变量的msb存放在低地址字节。有符号整型变量(signed int)也使用msb位作为标志位,并使用二进制的补码表示数值。 长整型变量(1ong int)长整型变量占用4个字节(byte),其它方面与整型变量(int)相似。 浮点型变量(float)浮点型变量占4个字节(byte),许多复杂的数学表达式都采用浮点变量数据类型。它用符号位表示数的符号,用阶码和尾数表示数的大小。用它们进行任何数学运算都需要使用由

7、编译器决定的各种不同效率等级的库函数。(补充存储格式),在编程时,为了书写方便,经常使用简化的缩写形式来定义变量的数据类型。其方法是在源程序开头使用#define语句。 例如: #define uchar unsigned char #define uint unsigned int,1.2.2.2变量的存储 变量的存储器类型是指该变量在8051单片机硬件系统中所使用的存储区域,并在编译时准确的定位。 8051系列单片机将程序存储器(ROM)和数据存储器(RAM)分开,并各有各自的寻址机构和寻址方式。8051系列单片机在物理上有四个存储空间: *片内程序存储器空间; *片外程序存储器空间, *

8、片内数据存储器空间; *片外数据存储器空间,KEIL uVision2所能支持的存储器类型:,注意的是在AT89C51芯片中RAM只有低128位,位于80H到FFH的高128位则在52芯片中才有用,并和特殊寄存器地址重叠。,定义变量时如果省略存储器类型,系统则会按编译模式SMALL、COMPACT或LARGE所规定的默认存储器类型去指定变量的存储区域。无论什么存储模式都可以声明变量在任何的8051存储区范围,然而把最常用的变量、命令放在内部数据区可以显著的提高系统性能。,C51支持的主要编译模式,1.2. 3 8051片内资源及位变量 1.2.3.1 特殊功能寄存器的C51定义 8051单片机

9、的内部高128个字节为专用寄存器区,其中51子系列有21个(52子系列有26个)特殊功能寄存器(SFR),它们离散的分布在这个区中,分别用于CPU并行口、串行口、中断系统、定时/计数器等功能单元及控制和状态寄存器。,对SFR的操作,只能采用直接寻址方式。为了能直接访问这些特殊功能寄存器,Keil C51扩充了两个关键字“sfr”、“sfr16”,可以直接对51单片机的特殊寄存器进行定义,这种定义方法与标准C51语言不兼容,只适用于对8051系列单片机C51编程。,定义方法如下: sfr 特殊功能寄存器名= 特殊功能寄存器地址常数; sfr16 特殊功能寄存器名= 特殊功能寄存器地址常数; 对于

10、8051片内I/O口,定义方法如下: sfr P1 = 0 x90; /定义P1口,地址90H sfr P2 = 0 xA0; /定义P1口,地址A0H sfr后面是一个要定义的名字,要符合标识符的命名规则,名字最好有一定的含义 等号后面必须是常数,不允许有带运算符的表达式,而且该常数必须在特殊功能寄存器的地址范围之内(80H-FFH)。sfr是定义8位的特殊功能寄存器, sfr16用来定义16位特殊功能寄存器,如8052的T2定时器,可以定义为:,sfr16 T2 = 0 xCC; /这里定义8052定时器2,地址为T2L=CCH,T2H=CDH 用sfr16定义16位特殊功能寄存器时,等号

11、后面是它的低位地址,高位地址一定要位于物理低位地址之上。注意的是,sfr16不能用于定时器0和1的定义。 对于需要单独访问SFR中的位,C51的扩充关键字sbit可以访问位寻址对象。,sbit定义某些持殊位,并接受任何符号名,“=”号后将绝对地址赋给变量名 这种地址分配,有三种方法: 1)sbit 位变量名位地址 sbit P1_1 = Ox91; 这样是把位的绝对地址赋给位变量。 同sfr一样,sbit的位地址必须位于80HFFH之间。 2)Sbit 位变量名特殊功能寄存器名位位置 sfr P3 = 0 xB0; sbit P3_1 = P3 1; /先定义一个特殊功能寄存器名,再指定位变量

12、名所在的位置。 当可寻址位位于特殊功能寄存器中时可采用这种方法。 3)sbit 位变量名字节地址位位置 sbit P3_1 = 0 xB0 1;,1.2.3.2 位寻址区及位变量定义,C51提供一个bdata的存储器类型,用于访问单片机的可位寻址区的数据 如: unsigned char bdata age; /在位寻址区定义ucsigned char类型的变量age int bdata score2; /在可位寻址区定义数组score2 sbit flag=age7 /用关键字sbit定义位变量来独立访问可寻址位对象的其中一位 C51提供关键字“bit”实现位变量的定义及访问。 bit fl

13、ag; / 将flag定义为位变量 bit valve_state; / 将valve_state定义为位变量 通常C51编译器会将位变量分配在位寻址区的某一位。,定义位变量时应注意以下问题,1)位变量不能定义成一个指针,如不能定义:bit * POINTER。 2) 不能定义位数组,如不能定义: bit array2。 3) bit与sbit的不同。bit不能指定位变量的绝对地址,当需要指定位变量的绝对地址(范围必须在0 x80-0 xff)时,需要使用sbit来定义。 例:sbit flag=P10;,也可使用sbit访问可位寻址对象的位。 bdata char jj ; * jj定义为b

14、data整型变量* int bdata sum2; /*在可位寻址区定义数组sum2,也称为可寻址位对象*/ sbit mybit7=jj7; *mybit7 定义为jj的第7位*/ sbit score12=sum112; * score12定义为sum1的第12位*/,可位寻址对象也可以字节寻址。 例: jj=0; *jj赋值为0*sbit定义要求基址对象的存储类型为bdata,否则只有绝对的特殊位定义(sbit)是合法的。位置(操作符)后的最大值依赖于指定的访问对象型,对于char、uchar而言是0-7,对于int、uint而言是015。 sbit定义要求基址对象的存储类型为bdata

15、,否则只有绝对的特殊位定义(sbit)是合法的。位置(操作符)后的最大值依赖于指定的访问对象型,对于char、uchar而言是0-7,对于int、uint而言是015。,1.3 自定义变量类型typedef,通常定义变量的数据类型时都是使用标准的关键字,方便别人阅读程序。但使用typedef可以有方便程序的移植和简化较长的数据类型定义 例如:程序设计者对变量的定义习惯了DELPHI的关键字,如整型数据习惯用关键字integer来定义,在用C51时还想用integer的话,你可以这样写: typedef int integer; integer a,b;,1.4 运算符与表达式,1.4.1赋值运

16、算 利用赋值运算符将一个变量与一个表达式连接起来的式子为赋值表达式,在表达式后面加“;”便构成了赋值语句。 使用=的赋值语句格式如下:变量 = 表达式; 例如: a = 0 x10; /将常数十六进制数10赋于变量a b = c = 2; /同时将2赋值给变量b,c d = e; /将变量e的值赋于变量d f = d-e; /将变量d-e的值赋于变量f 赋值语句的意义就是先计算出=右边的表达式的值,然后将得到的值赋给左边的变量。而且右边的表达式可以是一个赋值表达式。,1.4.2算术运算,1.4.2.1 算术运算符及算术表达式 C51中的算术运算符有如下几个,其中只有取正值和取负值运算符是单目运算符,其它则都是双目运算符: 十 (加法运算符,或正值符号) - (减法运算符,或负值符号) * (乘法运算符) / (除法运算将) (模(求余)运算符。例如5%3结果是5除以3所得的余数2),用算术运算符和括号将运算对象连接起来的式子称为算术表

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > PPT模板库 > PPT素材/模板

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号