学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt

上传人:牧羊曲112 文档编号:6564624 上传时间:2023-11-13 格式:PPT 页数:52 大小:4.40MB
返回 下载 相关 举报
学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt_第1页
第1页 / 共52页
学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt_第2页
第2页 / 共52页
学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt_第3页
第3页 / 共52页
学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt_第4页
第4页 / 共52页
学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt_第5页
第5页 / 共52页
点击查看更多>>
资源描述

《学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt》由会员分享,可在线阅读,更多相关《学期C程序设计(第三版)教材PPT-第3章-2讲稿.ppt(52页珍藏版)》请在三一办公上搜索。

1、主要内容,3.5 字符型数据 3.6 变量赋初值 3.7 各类数值型数据间的混合运算 3.8 算术运算符和算术表达式 3.9 赋值运算符和赋值表达式 3.10 逗号运算符和逗号表达式,3.5字符型数据,3.5.1 字符常量用单撇号括起来的一个字符是字符常量。例如,A、a等。,C允许一种特殊的字符常量,是以“”开头的字符序列称为转义字符。,显示屏上的运行结果:f空空空空空空空gde 空空空空空空j空k,例3.5 转义字符的使用#include void main()printf(空ab空ct空derftgn);printf(htibbj空kn);,打印机上的显示结果:fab空c空空空gde h空

2、空空空空空jik,3.5字符型数据,字符变量一个字符型变量用来存放字符常量,只能存放一个字符.定义形式:char c1,c2;c1=a;c2=b;在所有的编译系统中都规定以一个字节来存放一个字符,一个字符变量在内存中占一个字节。,3.5字符型数据,字符数据在内存中的存储形式及其使用方法将一个字符常量放到一个字符变量中,实际上是将该字符的相应的ASCII代码放到存储单元中。,如 x 的十进制ASCII码是120,y 的十进制ASCII码是121。对字符变量a,b赋予x和y值:a=x;b=y;实际上是在a,b两个单元内存放120和121的二进制代码:,例3.6 向字符变量赋予整数。#include

3、 void main()char c1,c2;c1=97;c2=98;printf(“%c%cn”,c1,c2);printf(“%d%dn”,c1,c2);,说明:在第和第4行中,将整数和分别赋给c1和c2,它的作用相当于以下两个赋值语句:c1;c2;因为a和b的ASCII码为和,运行结果:a 97 98光标,语言允许对整型变量赋以字符值,也允许对字符变量赋以整型值。在输出时,允许把字符变量按整型量输出,也允许把整型量按字符量输出。整型占2字节,字符型占1字节,字符型变量只能存放0-255范围内的整数。当整型量按字符型量处理时,只有低八位字节参与处理。,例3.7 大小写字母的转换#inclu

4、de void main()char c1,c2;c1=a;c2=b;c1=c1-32;c2=c2-32;printf(“c c,c1,c2);,说明:该程序是将小写字母a和b转换成大写字母A和B。从ASCII码表中可以看到每一个小写字母比它相应的大写字母的ASCII码大32。允许字符数据与整数直接进行算术运算。,运行结果:,字符型数据是可以与整型数据相互赋值,如 int i;char c;i=a;c=97;printf(“%c,%dn”,c,c”);printf(“%c,%dn”,i,i);输出:a,97 a,97,3.5字符型数据,说明:有些系统(如PDP,VAX-11,Turbo C)将

5、字符变量中的最高位作为符号位,也就是将字符处理成带符号的整数。signed char 型 取值范围-128至127usigned char 型 取值范围 0 至255,3.5字符型数据,字符串常量字符串常量是一对双撇号括起来的字符序列.合法的字符串常量:“How do you do.”,“CHINA”,“a”,“$123.45”可以输出一个字符串,如printf(“How do you do.”);,区分:,是字符常量,”是字符串常量,二者不同。如:假设被指定为字符变量:char c;c=a;”a”;c”CHINA”;,结论:不能把一个字符串常量赋给一个字符变量。,3.5字符型数据,规定:在每

6、一个字符串常量的结尾加一个“字符串结束标志”,以便系统据此判断字符串是否结束。规定以字符作为字符串结束标志。,如:一个字符串常量”,实际上在内存中是:,它占内存单元不是个字符,而是个字符,最后一个字符为。但在输出时不输出。,注意:在源程序中书写字符串常量时,不必加结束字符0,否则画蛇添足。,C无字符变量,有字符数组!,3.5字符型数据,3.6变量赋初值,(1)语言允许在定义变量的同时使变量初始化。如:int a=3;float f=3.56;char c=a;,(2)可以使被定义的变量的一部分赋初值。如:int a,b,c=5;(3)如果对几个变量赋以同一个初值,应写成:int a=3,b=3

7、,c=3;不能写成 int a=b=c=3;,注意:初始化不是在编译阶段完成的而是在程序运行时执行本函数时赋初值的,相当于有一个赋值语句。如:int a=3;相当于 int a;a=3;,整型、实型、字符型数据可以相互转换。例如:10+a+1.5-8765.1234*b 运算时,不同类型的数据要先转换成同一类型,后进行运算。转换规则如下:,左箭头表示必定的转换;纵向箭头表示不同类型的转换方向。箭头方向只表示数据类型级别的高低,由低到高转换!并不是表示转换过程!,3.7各类数值型数据间的混合运算,3.7各类数值型数据间的混合运算,假设已知:int i;float f;double d;long

8、e;则10+a+i*f-d/e计算机的执行过程:,1)10+a-int+int=int-10+97=107。2)i*f-i和f都转换为double,结果为double型。3)107由int型转为double型与i*f double型结果相加,结果为double型。4)d/e-d和e都转换为double参与运算,结果为double型。5)10+a+i*f-d/e-结果为double型以上类型转换有系统自动完成。,3.8算术运算符和算术表达式,3.8.1 运算符简介 的运算符有以下几类:(1)算术运算符(+-*/%)(2)关系运算符(|)(5)赋值运算符(及其扩展赋值运算符)(6)条件运算符(?:

9、)(7)逗号运算符(,),(8)指针运算符(*和)(9)求字节数运算符(sizeof)(10)强制类型转换运算符((类型))(11)分量运算符(-)(12)下标运算符()(13)其他(如函数调用运算符(),3.8算术运算符和算术表达式,3.8.2 算术运算符和算术表达式(1)基本的算术运算符:1)(加法运算符,或正值运算符。如:、)2)(减法运算符,或负值运算符。如:、)3)*(乘法运算符。如:*)4)(除法运算符。如:)5)(模运算符,或称求余运算符,两侧均应为整型数据,如:的值为)。前4种运算,如果运算量中有一个是实型,则结果 为双精度实型。,3.8算术运算符和算术表达式,对除法运算的说明

10、:两个整数相除(/)结果为整数。如果除数或被除数有一个为负值,则舍入的方向是不固定的。例如:-5/3在有的系统上,结果为-1;在有的系统上结果为-2。多数C编译系统(Turbo C)采用“向零取整”的方法。即:5/3=1,-5/3=-1,取整后向零靠拢。,(2)算术表达式和运算符的优先级与结合性基本的算术运算符:用算术运算符和括号将运算对象(也称操作数)连接起来的、符合语法规则的式子,称为算术表达式。运算对象包括常量、变量、函数等。例如:*.5 a是一个合法的表达式,3.8算术运算符和算术表达式,语言规定了运算符的优先级和结合性。在表达式求值时,先按运算符的优先级别高低次序执行,例如先乘除后加

11、减。规定了各种运算符的结合方向(结合性)算术运算符的结合方向为“自左至右”,即先左后右。,如何进行表达式求值?,运算符的优先级:语言中,运算符的运算优先级共分为15级。1级最高,15级最低。在表达式中,优先级较高的先于优先级较低的进行运算。而在一个运算量两侧的运算符优先级相同时,则按运算符的结合性所规定的结合方向处理。,在表达式求值时,先按运算符的优先级别高低次序执行。如果在一个运算符的对象两侧的运算符的优先级别相同,则按照规定的“结合方向”处理。,结合性是语言的独有概念。除单目运算符、赋值运算符和条件运算符是右结合性外,其它运算符都是左结合性。,运算符的结合性:语言中各运算符的结合性分为两种

12、,即左结合性(自左至右)和右结合性(自右至左)。例如算术运算符的结合性是自左至右,即先左后右。如有表达式x-y+z则y应先与“-”号结合,执行x-y运算,然后再执行+z的运算。这种自左至右的结合方向就称为“左结合性”。最典型的右结合性运算符是赋值运算符。如x=y=z,由于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。语言运算符中有不少为右结合性,应注意区别。,如何进行表达式求值?,(3)强制类型转换运算符 可以利用强制类型转换运算符将一个表达式转换成所需类型。一般形式:(类型名)(表达式)例如:(double)将转换成double类型(int)(x+y)将x+y的值转换成整型(fl

13、oat)(5%3)将5%3的值转换成float型,3.8算术运算符和算术表达式,注意:表达式应该用括号括起来;强制类型转换时,得到一个所需类型的中间变量,原来变量的类型不发生变化。,例3.8 强制类型转换。#include void main()float;int;=3.6;=(int);printf(x=%f,i=%dn,x,i);,说明:有两种类型转换,一种是运算时系统自动进行的类型转换,如3+6.5。第二种是强制类型转换。当自动类型转换不能实现目的时,可以用强制类型转换。,运行结果:x3.600000,i=3 光标,(4)自增、自减运算符 作用是使变量的值增或减如:,(在使用之前,先使的

14、值加(减),(在使用之后,使的值加(减),3.8算术运算符和算术表达式,i+与+i的区别:是先执行后,再使用的值;是先使用的值后,再执行。例如:;i的值先变成4,再赋给,j的值均为;先将 i的值3赋给,的值为,然后变为,注意:(1)自增(+)和自减(-)运算符,只能用于变量,而不能用于常量或表达式。6+或(a+b)+或(-i)+错误(2)+和-的结合方向是“自右向左”。-i+设i原值为3负号运算符和“+”运算符同优先级,而结合方向为“自右至左”所以相当于(i+)。但是,如果有printf(“%d”,-i+);则先取-i的值为-3,然后i增1。,*自增(减)运算符常用于循环语句中使循环变量自动加

15、。也用于指针变量,使指针指向下一个地址。,3.8算术运算符和算术表达式,(5)有关表达式使用中的问题说明ANSI C并没有具体规定表达式中的子表达式的求值顺序,允许各编译系统自己安排。例1:对表达式 a=f1()+f2()并不是所有的编译系统都先调用f1(),然后调用f2()。在有的情况下结果可能不同。有时会出现一些令人容易搞混的问题,因此务必要小心谨慎。例2:如果i的初值为3(i+)+(i+)+(i+),3.8算术运算符和算术表达式,语言中有的运算符为一个字符,有的运算符由两个字符组成,为避免误解,最好采取大家都能理解的写法。例如:不要写成i+j的形式,而应写成(i+)+j的形式,3.8算术

16、运算符和算术表达式,在调用函数时,实参数的求值顺序,标准并无统一规定。例如:的初值为,如果有下面的函数调用:printf(,i+)在有的系统中,从左至右求值,输出“3,3”。在多数系统中对函数参数的求值顺序是自右而左,printf函数输出的是“4,3”。以上这种写法不提倡,最好改写成 j=i+;printf(%d,%d,j,i)不要写出别人看不懂的也不知道系统会怎样执行程序!,3.9 赋值运算符和赋值表达式,(1)赋值运算符“”就是赋值运算符,作用是将一个数据赋给一个变量。如“”的作用是执行一次赋值操作。也可将一个表达式的值赋给一个变量.,(2)类型转换 如果赋值运算符两侧的类型不一致,但都是

17、数值型或字符型时,在赋值时要进行类型转换。将浮点型数据(包括单、双精度)赋给整型变量时,舍弃浮点数的小数部分。如:为整型变量,执行“i=3.56”的结果是使的值为,以整数形式存储在整型变量中.,将整型数据赋给单、双精度变量时,数值不变,但以浮点数形式存储到变量中 如:将23赋给float变量,即执行23,先将23转换成23.00000,再存储在中。将23赋给double型变量,即执行23,则将23补足有效位数字为23.00000000000000,然后以双精度浮点数形式存储到变量中。,3.9 赋值运算符和赋值表达式,将一个double型数据赋给float变量时,截取其前面7位有效数字,存放到f

18、loat变量的存储单元(4个字节)中。但应注意数值范围不能溢出。如:float f;double d=123.456789e100;f=d;就出现溢出的错误。如果将一个float型数据赋给double变量时,数值不变,有效位数扩展到16位,在内存中以8个字节存储。,3.9 赋值运算符和赋值表达式,字符型数据赋给整型变量时,由于字符只占1个字节,而整型变量为个字节,因此将字符数据(个二进位)放到整型变量存储单元的低位中。第一种情况:如果所用系统将字符处理为无符号的字符类型,或程序已将字符变量定义为unsigned char型,则将字符的位放到整型变量低位,高位补零例如:将字符376赋给int型变

19、量,3.9 赋值运算符和赋值表达式,第二种情况:如果所用系统(如Turbo C+)将字符处理为带符号的(即signed char),若字符最高位为,则整型变量高位补;若字符最高位为,则高位全补。这称为“符号扩展”,这样做的目的是使数值保持不变,如变量(字符376)以整数形式输出为2,的值也是。,3.9 赋值运算符和赋值表达式,将一个int、short、long型数据赋给一个char型变量时,只将其低8位原封不动地送到char型变量(即截断)。例如:int i=289;char c=a;c=i;赋值情况:,c的值为33,如果用“%c”输出c,将得到字符“!”(其ASCII码为33)。,3.9 赋

20、值运算符和赋值表达式,将带符号的整型数据(int型)赋给long型变量时,要进行符号扩展,将整型数的16位送到long型低16位中:如果int型数据为正值(符号位为),则long型变量的高16位补;如果int型变量为负值(符号位为),则long型变量的高16位补,以保持数值不改变。反之,若将一个long型数据赋给一个int型变量,只将long型数据中低16位原封不动地送到整型变量(即截断)。,3.9 赋值运算符和赋值表达式,例如:int a;long b;a=b 赋值情况如图:,3.9 赋值运算符和赋值表达式,如果65536(八进制数0200000),则赋值后值为,3.9 赋值运算符和赋值表达

21、式,例如:int a;long b;a=b 赋值情况如图:,unsigned int-long,只需要将高位补0。unsigned int-intunsigned long-longunsigned short-short例如:unsigned int a=65535;int b;b=a;,只需要将unsigned变量的内容原样送到signed变量中,但如果数据超过相应的整数范围,则会出现数据错误。,3.9 赋值运算符和赋值表达式,的值为-1,将非unsigned型数据赋给长度相同的unsigned型变量,也是原样照赋(连原有的符号位也作为数值一起传送)。,3.9 赋值运算符和赋值表达式,例3

22、.9 有符号数据传送给无符号变量。#include void main()unsigned;int=-1;a=;printf(%un,);,说明:“%u”是输出无符号数时所用的格式符。如果为正值,且在32767之间,则赋值后数值不变。,运行结果:65535,(2)类型转换-总结:1、不同类型的整型数据间的赋值归根到底就是一条:按存储单元中的存储形式直接传送。2、在不同类型数据之间赋值时,常会出现意想不到的结果,而编译系统并不提示出错,全靠编程人员的经验来解决。,(3)复合的赋值运算符 在赋值符“”之前加上其他运算符,可以构成复合的运算符。例如:等价于*等价于*()等价于,3.9 赋值运算符和赋

23、值表达式,为便于记忆,可以这样理解:a+=b(其中a为变量,b为表达式)a+=b(将有下划线的“a+”移到“=”右侧)|_ a=a+b(在“=”左侧补上变量名a),注意:如果是包含若干项的表达式,则相当于它有括号。如:x%=y+3 x%=(y+3)|_ x=x%(y+3)(不要错写成x=x%y+3),凡是二元(二目)运算符,都可以与赋值符一起组合成复合赋值符。,语言规定可以使用10种复合赋值运算符:,*,|,3.9 赋值运算符和赋值表达式,复合赋值符这种逆波兰式写法,对初学者可能不习惯,但十分有利于编译处理,能提高编译效率并产生质量较高的目标代码。,(4)赋值表达式 由赋值运算符将一个变量和一

24、个表达式连接起来的式子称为“赋值表达式”。一般形式为:例如:“5”是一个赋值表达式,3.9 赋值运算符和赋值表达式,对赋值表达式求解的过程是:求赋值运算符右侧的“表达式”的值;赋给赋值运算符左侧的变量。例如:赋值表达式“=3*5”的值为15,执行表达式后,变量a的值也是15。,注意:一个表达式应该有一个值。,左值(lvalue):赋值运算符左侧的标识符变量可以作为左值;而表达式就不能作为左值(如a+b);常变量也不能作为左值,,右值(lvalue):出现在赋值运算符右侧的表达式 左值也可以出现在赋值运算符右侧,因而左值都可以作为右值。,3.9 赋值运算符和赋值表达式,赋值表达式中的“表达式”,

25、又可以是一个赋值表达式.例如:a=(b=5),分析:赋值运算符按照“自右而左”的结合顺序,因此,“(b5)”外面的括弧可以不要,即“a=(b=5)”和“a=b=5”等价.,3.9 赋值运算符和赋值表达式,请分析下面的赋值表达式(a=3*5)=4*3,分析:先执行括弧内的运算,将15赋给a,然后执行4*3的运算,得12,再把12赋给a。最后a的值为12,整个表达式的值为12。可以看到(a=3*5)出现在赋值运算符的左侧,因此赋值表达式(a=3*5)是左值。,注意:在对赋值表达式(a=3*5)求解后,变量a得到值15执行(a=3*5)=4*3时,实际上是将4*3的积12赋给变量a,而不是赋给3*5

26、。,不能写成:a=3*5=4*3,赋值表达式也可以包含复合的赋值运算符。如:a+=a-=a*a,分析:此赋值表达式的求解步骤如下 先进行“*”的运算,它相当于*,a的值12144132。再进行“132”的运算,相当于=a+(-132),a的值为132-132-264。,3.9 赋值运算符和赋值表达式,将赋值表达式作为表达式的一种,使赋值操作不仅可以出现在赋值语句中,而且可以以表达式形式出现在其他语句(如输出语句、循环语句等)中.如:printf(%d,a=b);,分析:如果b的值为3,则输出a的值(也是表达式a=b的值)为3。在一个语句中完成了赋值和输出双重功能。,3.9 赋值运算符和赋值表达

27、式,3.10 逗号运算符和逗号表达式,逗号运算符:将两个表达式连接起来,又称为“顺序求值运算符”如:5,,一般形式:表达式,表达式,求解过程:先求解表达式,再求解表达式。整个逗号表达式的值是表达式的值。,逗号表达式的值为14,例:逗号表达式*5,*,分析:赋值运算符的优先级别高于逗号运算符,因此应先求解*5.,的值为5,然后求解*,得。整个逗号表达式的值为。,一个逗号表达式又可以与另一个表达式组成一个新的逗号表达式 如:(*,*),a+5 先计算出的值等于15,再进行*的运算得60(但值仍为 15),再进行a+5得20,即整个表达式的值为20。,3.10 逗号运算符和逗号表达式,逗号表达式的一

28、般形式可以扩展为 表达式,表达式,表达式,表达式它的值为表达式的值。,逗号运算符是所有运算符中级别最低的例:(,*),*3,赋值表达式,将一个逗号表达式的值赋给,的值等于,逗号表达式,包括一个赋值表达式和一个算术表达式,的值为,整个逗号表达式的值为18。,3.10 逗号运算符和逗号表达式,注意:并不是任何地方出现的逗号都是作为逗号运算符。例如函数参数也是用逗号来间隔的。如:printf(“%d,%d,%d”,a,b,c);,“,”并不是一个逗号表达式,它是printf函数的3个参数,printf(“%d,%d,%d”,(a,b,c),b,c);,“(,)”是一个逗号表达式,它的值等于的值。,3.10 逗号运算符和逗号表达式,天道酬勤!,作业:3.2;3.5;3.7;3.9;3.10;3.12,

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

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


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号