文档详情

第三章运算符与表达式.doc

新**
实名认证
店铺
DOC
969.51KB
约8页
文档ID:547422337
第三章运算符与表达式.doc_第1页
1/8

C程序设计 备课笔记第三章 运算符与表达式3、1 C运算符简介运算符:狭义的运算符是表示各种运算的符号表达式:使用运算符将常量、变量、函数连接起来,构成表达式C语言运算符丰富,范围很宽,把除了控制语句和输入/输出以外的几乎所有的基本操作都作为运算符处理,所以C语言运算符可以看作是操作符C语言丰富的运算符构成C语言丰富的表达式(是运算符就可以构成表达式)运算符丰富、表达式丰富、灵活在C语言中除了提供一般高级语言的算术、关系、逻辑运算符外,还提供赋值符运算符,位操作运算符、自增自减运算符等等甚至数组下标,函数调用都作为运算符C的运算符有以下几类:本章主要介绍算术运算符(包括自增自减运算符)、赋值运算符、逗号运算符,其它运算符在以后相关章节中结合有关内容陆续进行介绍3、2 算术运算符和算术表达式1、算术运算符+(加法运算符如3+5)-(减法运算符或负值运算符如5-2,-3)*(乘法运算符。

如3*5)/(除法运算符如5/3,5.0/3)%(模运算符或求余运算符,%要求两侧均为整型数据如7%4的值为3)除了负值运算符-单目运算符外,其它都是双目运算符说明:(1) 两个整数相除的结果为整数,如5/3的结果为1,舍去小数部分但是如果除数或被除数中有一个为负值,则舍入的方向是不固定的,多数机器采用“向0取整”的方法(实际上就是舍去小数部分,注意:不是四舍五入)2) 如果参加+,-,*,/运算的两个数有一个为实数,则结果为double型,因为所有实数都按double型进行计算3) 求余运算符%,要求两个操作数均为整型,结果为两数相除所得的余数求余也称为求模一般情况,余数的符号与被除数符号相同例如:-8%5=-3;8%-5=32、算术表达式算术表达式:用算术运算符和括号将运算对象(也称操作数)连接起来的、符合C语法规则的式子,称为算术表达式运算对象可以是常量、变量、函数等例如,下面是一个合法的C算术表达式a*b/c-1.5+’a’注意:C语言算术表达式的书写形式与数学表达式的书写形式有一定的区别:(1) C语言算术表达式的乘号(*)不能省略例如:数学式b2-4ac,相应的C表达式应该写成:b*b-4*a*c。

2) C语言表达式中只能出现字符集允许的字符例如,数学πr2相应的C表达式应该写成:PI*r*r其中PI是已经定义的符号常量)(3) C语言算术表达式不允许有分子分母的形式例如,(a+b)/(c+d)4) C语言算术表达式只使用圆括号改变运算的优先顺序(不要指望用{}[])可以使用多层圆括号,此时左右括号必须配对,运算时从内层括号开始,由内向外依次计算表达式的值3、(算术)运算符的优先级与结合性(P.233附录IV)C语言规定了进行表达式求值过程中,各运算符的“优先级”和“结合性”1)C语言规定了运算符的“优先级”和“结合性”在表达式求值时,先按运算符的“优先级别”高低次序执行如表达式:a-b*c等价于a-(b*c),“*”运算符优先级高于“-”运算符2)如果在一个运算对象两侧的运算符的优先级别相同,则按规定的“结合方向”处理例如:a-b+c,到底是(a-b)+c还是a-(b+c)?(b先与a参与运算还是先于c参与运算?)查附录IV可知:+/-运算优先级别相同,结合性为“自左向右”,即就是说b先与左边的a结合所以a-b+c等价于(a-b)+c左结合性(自左向右结合方向):运算对象先与左面的运算符结合。

右结合性(自右向左结合方向):运算对象先与右面的运算符结合3)在书写多个运算符的表达式时,应当注意各个运算符的优先级,确保表达式中的运算符能以正确的顺序参与运算对于复杂表达式为了清晰起见可以加圆括号“()”强制规定计算顺序3、3 赋值运算符和赋值表达式1、 赋值运算符、赋值表达式赋值运算符:赋值符号“=”就是赋值运算符赋值表达式:由赋值运算符组成的表达式称为赋值表达式一般形式:〈变量〉〈赋值符〉〈表达式〉赋值表达式的求解过程:将赋值运算符右侧的表达式的值赋给左侧的变量,同时整个赋值表达式的值就是刚才所赋的值赋值的含义:将赋值运算符右边的表达式的值存放到左边变量名标识的存储单元中例如:x=10+y; 执行赋值运算(操作),将10+y的值赋给变量x,同时整个表达式的值就是刚才所赋的值说明:(1) 赋值运算符左边必须是变量,右边可以是常量、变量、函数调用或常量、变量、函数调用组成的表达式例如:x=10 y=x+10 y=func()都是合法的赋值表达式2) 赋值符号“=”不同于数学的等号,它没有相等的含义相等)例如:C语言中x=x+1是合法的(数学上不合法),它的含义是取出变量x的值加1,再存放到变量x中。

3) 赋值运算时,当赋值运算符两边数据类型不同时,将由系统自动进行类型转换转换原则是:先将赋值号右边表达式类型转换为左边变量的类型,然后赋值l 将实型数据(单、双精度)赋给整型变量,舍弃实数的小数部分l 将整型数据赋给单、双精度实型变量,数值不变,但以浮点数形式存储到变量中l 将double型数据赋给float型变量时,截取其前面7位有效数字,存放到float变量的存储单元中(32bits)但应注意数值范围不能溢出将float型数据赋给double型变量时,数值不变,有效位数扩展到16位(64bits)l 字符型数据赋给整型变量时,由于字符只占一个字节,而整型变量为2个字节,因此将字符数据(8bits)放到整型变量低8位中有两种情况:如果所使用的系统将字符处理为无符号的量或对unsigned char型变量赋值,则将字符的8位放到整型变量的低8位,高8位补0如果所使用的系统将字符处理为带符号的量(signed char)(如Turbo C),若字符最高位为0,则整型变量高8位补0;若字符最高位为1,则整型变量高8位全补1这称为符号扩展,这样做的目的是使数值保持不变l 将一个int,short,long型数据赋给一个char型变量时,只是将其低8位原封不动地送到char型变量(即截断)。

l 将带符号的整型数据(int型)赋给long型变量时,要进行符号扩展即,将整型数的16位送到long型低16位中,如果int型数值为正,则long型变量的高16位补0,如果int型数值为负,则long型变量的高16位补1,以保证数值不变反之,若将一个long型数据赋给一个int型变量,只将long型数据中低16位原封不动地送到整型变量(即截断)l 将unsigned int型数据赋给long int型变量时,不存在符号扩展问题,只要将高位补0即可将一个unsigned类型数据赋给一个占字节相同的整型变量,将unsigned型变量的内容原样送非unsigned型变量中,但如果数据范围超过相应整数的范围,则会出现数据错误l 将非unsigned型数据赋给长度相同的unsigned型变量,也是原样照赋总之:不同类型的整型数据间的赋值归根到底就是:按照存储单元的存储形式直接传送由长型整数赋值给短型整数,截断直接传送;由短型整数赋值给长型整数,低位直接传送,高位根据低位整数的符号进行符号扩展)4) C语言的赋值符号“=”除了表示一个赋值操作外,还是一个运算符,也就是说赋值运算符完成赋值操作后,整个赋值表达式还会产生一个所赋的值,这个值还可以利用。

赋值表达式的求解过程是:l 先计算赋值运算符右侧的“表达式”的值l 将赋值运算符右侧“表达式”的值赋值给左侧的变量l 整个赋值表达式的值就是被赋值变量的值例如:分析x=y=z=3+5这个表达式根据优先级:原式óx=y=z=(3+5);根据结合性(从右向左):óx=(y=(z=(3+5)))óx=(y=(z=3+5))z=3+5:先计算3+5,得值8赋值给变量z,z的值为8,(z=3+5)整个赋值表达式值为8;y=(z=3+5):将上面(z=3+5)整个赋值表达式值8赋值给变量y,y的值为8,(y=(z=3+5))整个赋值表达式值为8;x=(y=(z=3+5)):将上面(y=(z=3+5))整个赋值表达式值8赋值给变量,z的值为8,整个表达式x=(y=(z=3+5))的值为8最后,x,y,z都等于8运算步骤:序号表达式变量及值表达式的值1z=3+5z(8)82y=(z=3+5)y(8)83x=(y=(z=3+5))x(8)8将赋值表达式作为表达式的一种,使赋值操作不仅可以出现在赋值语句中,而且可以以表达式的形式出现在其它语句中2、 复合赋值运算符在赋值符“=”之前加上某些运算符,可以构成复合赋值运算符,复合赋值运算符可以构成赋值表达式。

C语言中许多双目运算符可以与赋值运算符一起构成复合运算符,即:+=,-=,*=,/=,%=,<<=,>>=,&=,|=,^=<变量><双目运算符>=<表达式><变量>=<变量><双目运算符><表达式>复合赋值表达式一般形式:等价于:例如:n+=1 等价于 n=n+1x*=y+1 等价于 x=x*(y+1) 注意:赋值运算符、复合赋值运算符的优先级比算术运算符低3、 赋值运算符、赋值表达式举例(1) a=5(2) a=b=5(3) a=(b=4)+(c=3)(4) 假如a=12,分析:a+=a-=a*aa+=a-=a*aóa+=a-=(a*a)óa+=(a-=(a*a))óa+=(a=a-(a*a))óa+=(a=a-a*a)óa=a+(a=a-a*a)3、 4 自增、自减运算符单目运算符,使变量的值增1或减1如:++i,i++ --i,i—注意:(1) ++i,--i(前置运算):先自增、减,再参与运算;i++,i—(后置运算):先参与运算, 再自增、减例如:i=3,分析j=++i; j=i++;(2) 自增、减运算符只用于变量,而不能用于常量或表达式例如:6++,(a+b)++,(-i)++都不合法。

3) ++,--的结合方向是“自右向左”(与一般算术运算符不同)例如:-i++ó-(i++) 合法4) 自增、自减运算符常用于循环语句中,使循环变量自动加1,也用于指针变量,使指针指向下一个地址有关表达式使用过程中的问题说明(1) C运算符和表达式使用灵活,利用这一点可以巧妙处理许多在其它语言中难以处理的问题但是ANSI C并没有具体规定表达式中的子表达式的求值顺序,允许各编译系统自己安排这可能导致有些表达式对不同编译系统有不同的解释,并导致最终结果的不一致例1:a=f1()+f2()中f1,f2哪个先调用例2:i=3,表达式(i++)+(i++)+(i++)的值有些系统等价3+4+5,Turbo C等价3+3+3(2) C语言有的运算符为一个字符,有的由两个字符组成,C编译系统在处理时尽可能多地将若干字符组成一个运算符(在处理标识符、关键字时也按同一原则处理)如i+++j将解释为(i++)+j而不是i+(++j)。

下载提示
相似文档
正为您匹配相似的精品文档