第2章 基本的程序语句.ppt_第1页
第2章 基本的程序语句.ppt_第2页
第2章 基本的程序语句.ppt_第3页
第2章 基本的程序语句.ppt_第4页
第2章 基本的程序语句.ppt_第5页
已阅读5页,还剩50页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1,预备知识 基本数据类型; 常量和变量; 常用运算符和表达式; 运算符的优先级与结合性,第 二 章 基本的程序语句,2,字节和位 内存以字节为单元组成 每个字节有一个地址 一个字节一般由8个二进制位组成 每个二进位的值是0或1,2.0 预备知识,3,数值的表示方法 原码:最高位为符号位,其余各位为数值本身的绝对值 反码: 正数:反码与原码相同 负数:符号位为1,其余位对原码取反 补码: 正数:原码、反码、补码相同 负数:最高位为1,其余位为原码取反,再对整个数加1,9-5=4 9+7=(16)12=4,2.0 预备知识,4,负数补码转换成十进制数:最高位不动,其余位取反加1,例 补码:111

2、11001 取反:10000110 加1: 10000111=-7,5,数据类型总表,2.1 数据类型,6,2.1 数据类型(Data Type),数据为什么要区分类型?,数据类型决定: 1. 数据占内存字节数 2. 数据取值范围 3. 其上可进行的操作,7,2.1.1 基本数据类型,int 整数,在目前绝大多数机器上占4个字节。TC2中是2个字节,float 单精度浮点数,一般是4个字节长,double 双精度浮点数,一般是8个字节长,char 字符,一般是1个字节长 用来表示256个ASCII字符,或者0-255的整数,8,数据类型修饰符,short short int,短整数,一般2个字

3、节长。通常简写为short,long long int,长整数,一般是4个字节长。通常简写为long long double,长双精度(高精度)浮点数,一般是10个字节长。,signed 用来修饰char、int(short、long),说明他们是有符号的整数(正整数、0和负整数)。一般缺省都是有符号的,所以这个修饰符通常省略,unsigned 用来修饰char、int (short、long),说明他们是无符号的整数(正整数和0),9,基本数据类型,整型,字符型,实型,有,无,说明:数据类型所占字节数随机器硬件不同而不同,上表以IBM PC机为例:,10,数据在内存中的存储格式,整型 实型

4、字符型,11,标识符 定义:用来标识变量名、常量名、函数名等的字符序列 组成: 只能由字母、数字、下划线组成,且第一个字母必须是字母或下划线 大小写敏感 不能使用关键字 长度:最长32个字符 命名原则: 见名知意 不宜混淆 如l与I, o与0,例:判断下列标识符号合法性 sum Sum M.D.John day Date 3days student_name #33 lotus_1_2_3 char ab _above $123,M.D.John,3days,#33,char,$123,ab,2.2 常量与变量,12,概念:其值可以改变的量 变量名与变量值 变量定义的一般格式: 数据类型 变量

5、1,变量2,变量n;,变量初始化:定义时赋初值,例: int a,b,c; float data;,决定分配字节数 和数的表示范围,合法标识符,例: int a=2,b,c=4; char ch=A; int x=1,y=1,z=1; int x=y=z=1;,变量的使用:先定义,后使用,例1 int student; stadent=19; /Undefined symbol statent in function main,例2 float a,b,c; c=a%b; /Illegal use of floating point in function main,变量定义位置:一般放在函数

6、开头,变量,13,整型变量 占字节数随机器不同而不同,一般占一个机器字 shortintlong 可用sizeof(类型标识符)测量,实型变量 float:占4字节,提供7位有效数字 double:占8字节,提供1516位有效数字,字符型变量 字符变量存放字符ASCII码 char与int数据间可进行算术运算,例 float a; a=111111.111; /* a=111111.1*/ double b; b=111111.111; /* b=111111.111*/,例 a=D; /* a=68; */ x=A+5; /* x=65+5; */ s=!+G /* s=33+71; */,

7、没有字符串变量,用字符数组存放,14,例 #define PRICE 12.5 main() int num=3; float total; char ch1,ch2=D; total=num*PRICE; ch1=ch2-A+a; printf(“total=%f,ch1=%cn”,total,ch1); ,运行结果: total=37.500000, ch1=d,15,直接常量: 整型常量 实型常量 字符常量 字符串常量,常量(Constant) 定义:程序运行时其值不能改变的量(即常数) 分类:,符号常量 : 用标识符代表常量,16,整型常量,整型常量(整常数) 18、-31 长整型常量

8、 123l、123L、123456l、123456L 无符号型常量 123u、 123U 无符号长整型常量 123lu、123lU 、123Lu 、123LU,整型常量的类型 根据其值所在范围确定其数据类型,例 30000 为int型 65536 为long int 型,17,整型常量(八进制与十六进制),以数字“0”开始的整型常数是八进制数 022、-037 010和10大小不一样 因为八进制并不常用,所以此种表示法比较少见 以“0 x”或者“0X”开始的整型常数是十六进制 AF和af用来表示十进制的1015 十六进制的形式比较常用,尤其在进行位一级的控制的时候 0 x12、-0 x1F,

9、-0 x1f,问题: 0123 = ( )10 0 x123 = ( )10 0Xff = ( )10,18,实型常量,实型常量表示形式 十进制小数形式(必须有小数点) 如:0.123, .123, 123.0, 123. 指数形式 (e或E之前必须有数字;指数必须为整数) 如:12.3e3 ,123E2, 1.23e4 , e-5 , 1.2E-3.5 实型常量的类型 默认double型 单精度实型常量 123.45f、 456.78F、1e-2f、4.5e3F 长双精度型常量 123.45l、 456.78L、1e-2l、4.5e3L,aaa,19,定义:用单引号括起来的单个普通字符或转义

10、字符.,字符常量的值:该字符的ASCII码值,如 101 -A 012 -n 376 - x61 -a 60 -0 483 -(),例: A-101-x41-65,如 A65, a97, 048 , n10,如 a A ? n 101,转义字符:反斜线后面跟一个字符或一个代码值表示,例 转义字符举例 main() printf(101 x42 Cn); printf(I say:How are you?n); printf(C Programn); printf(Turbo C); ,运行结果:(屏幕显示) A B C Isay:”How are you?” C Program Turbo C

11、,例 main() printf(“Yb=n”); ,运行结果: 屏幕显示:= 打印机输出:,字符(Character)常量,20,字符常量与字符串常量不同,字符串常量 定义:用双引号(“”)括起来的字符序列 存储:每个字符串尾自动加一个 0 作为字符串结束标志,例: char ch; ch=“A”;,21,符号常量(宏常量),符号常量: 用标识符代表常量 定义格式: #define 符号常量 常量 一般采用大写字母表示 不是语句,而是一种编译预处理命令 宏替换,如 #define PI 3.14159,#include #define PI 3.14159 #define R 5.3 mai

12、n() printf(area = %fn, PI * R * R); printf(circumference = %fn, 2 * PI * R); ,22,const常量,用const修饰定义的变量为常量 const float pi = 3.1425926; 常量只能在定义时赋值,然后不能再改变其值 常数、 const常量、符号常量,都可以用来表示一个永远不会改变的数 前者不建议直接使用,而用后三者代替,23,2.4 运算符和表达式,24,运算符功能 与操作数关系 要求操作数个数 要求操作数类型 运算符优先级别 结合方向 结果的类型,学习运算符应注意:,25,基本算术运算符: + -

13、* / % 优先级: - * / % + - (2) (3) (4) 结合方向:从左向右 说明: “-” 为单目运算符时,右结合性 两整数相除,结果为整数 %要求两侧均为整型数据,例 5/2 = -5/2.0 =,例 5%2 = -5%2 = 1%10 = 5%1 = 5.5%2,例 5/2 = 2 -5/2.0 = -2.5,例 5%2 = 1 -5%2 = -1 1%10 = 1 5%1 = 0 5.5%2 (),算术运算符和表达式,26,常用的标准数学函数,算术运算符和表达式,27,作用:使变量值加1或减1 种类: 前置 +i, -i (先执行i+1或i-1,再使用i值) 后置 i+,i

14、- (先使用i值,再执行i+1或i-1),例 j=3; k=+j; j=3; k=j+; j=3; printf(“%d”,+j); j=3; printf(“%d”,j+); a=3;b=5;c=(+a)*b; a=3;b=5;c=(a+)*b;,/k=4,j=4,/k=3,j=4,/4,/3,/c=20,a=4,/c=15,a=4,自增、自减运算符+ -,28,说明: + - 不能用于常量和表达式,如5+,(a+b)+ + -结合方向: 自右向左 优先级:- + - - * / % - + - (2) (3) (4),自增、自减运算符+ -,例 -i+ -(i+) i=3; printf(

15、“%d”,-i+); /-3,例 -i+ i=3; printf(“%d”,-i+);,29,简单赋值运算符 符号: = 格式: 变量标识符=表达式 作用:将一个数据(常量或表达式)赋给一个变量,复合赋值运算符 种类:+= -= *= /= %= = = d=func(); c=d+2;,赋值运算符和表达式,30,结合方向:自右向左 优先级: 14 左侧必须是变量,不能是常量或表达式,赋值表达式的值与变量值相等,且可嵌套,赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型,例 3=x-2*y; a+b=3;,例 float f; int i; i=10; f=i; 则 f=10.0,

16、例 int i; i=2.56; /结果i=2;,例: a=b=c=5 a=(b=5) a=5+(c=6) a=(b=4)+(c=6) a=(b=10)/(c=2),/表达式值为5,a,b,c值为5,/ b=5;a=5,/表达式值11,c=6,a=11,/表达式值10,a=10,b=4,c=6,/表达式值5,a=5,b=10,c=2,赋值运算符说明:,31,例: a=12; a+=a-=a*a,例: int a=2; a%=4-1; a+=a*=a-=a*=3;,/a=-264 等价于a=a+(a=a-(a*a),/a=0 等价于a=a+(a=a*(a=a-(a=a*3),结合方向:自右向左

17、优先级: 14 左侧必须是变量,不能是常量或表达式,赋值表达式的值与变量值相等,且可嵌套,赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型,赋值运算符说明:,32,形式:表达式1,表达式2,表达式n 结合性:从左向右 优先级: 15 逗号表达式的值:等于表达式n的值 用途:常用于循环for语句中,例 a=3*5,a*4 a=3*5,a*4,a+5 例 x=(a=3,6*3) x=a=3,6*a 例 a=1;b=2;c=3; printf(“%d,%d,%d”,a,b,c); printf(“%d,%d,%d”,(a,b,c),b,c);,/a=15,表达式值60,/a=15,表达式

18、值20,/赋值表达式,表达式值18,x=18,/逗号表达式,表达式值18,x=3,/1,2,3,/3,2,3,逗号运算符和表达式,33,形式:表达式1,表达式2,表达式n 结合性:从左向右 优先级: 15 逗号表达式的值:等于表达式n的值 用途:常用于循环for语句中,例: #include main() int x,y=7; float z=4; x=(y=y+6,y/z); printf(x=%dn,x); ,运行结果:x=3,逗号运算符和表达式,34,关系运算符 种类:= != 结合方向:自左向右 优先级别:,例 ca+b /c(a+b) ab!=c /(ab)!=c a=bc /a=(

19、bc),关系表达式的值:是逻辑值“真”或“假”,用1和0表示,例 int a=3,b=2,c=1,d,f; ab (ab)=c b+cb f=abc,/表达式值1,/表达式值1,/表达式值0,/d=1,/f=0,关系运算符和表达式,35,关系运算注意:,例 若a=0; b=0.5; x=0.3; 则 a=x=b的值为,0,例 5278在C中是允许的, 值为,0,例 int i=1, j=7,a; a=i+(j%4!=0); 则a=,2,例 a0 结果为 A100 结果为,1,0,36,例 注意区分“=”与“=” int a=0,b=1; if(a=b) printf(“a equal to b

20、”); else printf(“a not equal to b”);,例 应避免对实数作相等或不等的判断 如 1.0/3.0*3.0 =1.0 结果为 可改写为:fabs(1.0/3.0*3.0-1.0)1e-6,0,关系运算注意:,不能用关系运算符比较字符串的大小,37,逻辑运算符 种类: ! b=5; !a a,例 (a=b)?Y:N (x%2=1)?1:0 (x=0)?x:-x (c=a x0,表达式值为a xy?1:1.5 /xy ,值为1.0; xy ,值为1.5,条件运算符与表达式,43,隐式转换 什么情况下发生 运算转换-不同类型数据混合运算时 赋值转换-把一个值赋给与其类型

21、不同的变量时 输出转换-输出时转换成指定的输出格式 函数调用转换-实参与形参类型不一致时转换 运算转换规则:不同类型数据运算时先自动转换成同一类型,2.4.7 数据类型的转换,44,45,一般形式:(类型名)(表达式) 例 (int)(x+y) (int)x+y (double)(3/2) (int)3.6 说明:强制转换得到所需类型的中间变量,原变量类型不变,例 main() float x; int i; x=3.6; i=(int)x; printf(“x=%f,i=%d”,x,i); 结果:x=3.600000,i=3,精度损失问题,显式转换(强制转换),46,优先级,能背下优先级表的人凤毛麟角 用括号来控制运算顺序更直观、方便,并减少出错的概率,47, 2.4.6 复杂表达式的计算顺序 运算符的优先级与运算方向,48,自右向左,49,2.3 一维简单数组,数组是一种具有相同数据类型的变量的集合 。,一维数组的定义格式: 数组大小;,如:int a6; 说明:数组名为a,它有6个元素,分别为a0、a1、 a2、 a3、 a4、 a5,每个元素都代表着一个整型变量。 数组在内存中是按顺序连续存放的,占用的内存大小为每一个元素占用内存的大小的和。,50,【例2

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论