所有的浮点运算都是以双精度进行的,即使仅含 float单精度量运算的表达式,也 要先转换成 double型,再作运算 char型和 short型参与运算时,必须先转换成int型。 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为 左边量的类型。如果右边量的数据类型长度比左边长时,将丢失一部分数据,这 样会降低精度。图2.1表示了类型自动转换的规则。 、强制类型转换 强制类型转换是通过强制类型转换运算符来实现的。其一般形式为:(类型说明符)(表 达式)其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。例如:(foat a把a转换为实型,(intx+y)把x+y的结果转换为整型。在使用强制转换时应注意以 下问题: 类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(in)(x+y)写成 (int)x+y则成了把x转换成int型之后再与y相加了 无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进 行的临时性转换,而不改变数据说明时对该变量定义的类型。 6.运算符 (一)算术运算符和算术表达式 加法运算符“+”∵:加法运算符为双目运算符,即应有两个量参与加法运算。如a+b,418 等。具有左结合性 2.减法运算符“”:减法运算符为双目运算符。但“”也可作负值运算符,此时为单目运 算,如-x-5等具有左结合性 3乘法运算符“*”:双目运算,具有左结合性 4.除法运算符“灬:双目运算,具有左结合性。参与运算量均为整型时,结果也为整型 舍去小数。如果运算量中有一个是实型,则结果为双精度实型 printf("nIn%d, %dIn, 20/7,-20/7) printf("%f,%n",20.0/7-20.0/7) 结果为:2,-2 2.857143,-2.857143 本例中,20/7,-207的结果均为整型,小数全部舍去。而20.07和-2007由于有实数 参与运算,因此结果也为实型。 5求余运算符(模运算符)%”∵:双目运算,具有左结合性。要求参与运算的量均为整型 求余运算的结果等于两数相除后的余数
11 ⚫ 所有的浮点运算都是以双精度进行的,即使仅含 float 单精度量运算的表达式,也 要先转换成 double 型,再作运算。 ⚫ char 型和 short 型参与运算时,必须先转换成 int 型。 ⚫ 在赋值运算中,赋值号两边量的数据类型不同时, 赋值号右边量的类型将转换为 左边量的类型。 如果右边量的数据类型长度比左边长时,将丢失一部分数据,这 样会降低精度。图 2.1 表示了类型自动转换的规则。 2、强制类型转换 强制类型转换是通过强制类型转换运算符来实现的。其一般形式为: (类型说明符) (表 达式) 其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。例如:(float) a 把 a 转换为实型,(int)(x+y) 把 x+y 的结果转换为整型。在使用强制转换时应注意以 下问题: ⚫ 类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成 (int)x+y 则成了把 x 转换成 int 型之后再与 y 相加了。 ⚫ 无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进 行的临时性转换,而不改变数据说明时对该变量定义的类型。 6.运算符 (一)算术运算符和算术表达式 1.加法运算符“+”:加法运算符为双目运算符,即应有两个量参与加法运算。如 a+b,4+8 等。具有左结合性。 2.减法运算符“-”:减法运算符为双目运算符。但“-”也可作负值运算符,此时为单目运 算,如-x,-5 等具有左结合性。 3.乘法运算符“*”:双目运算,具有左结合性。 4.除法运算符“/”:双目运算,具有左结合性。参与运算量均为整型时, 结果也为整型, 舍去小数。如果运算量中有一个是实型,则结果为双精度实型。 void main( ) { printf("\n\n%d,%d\n",20/7,-20/7); printf("%f,%f\n",20.0/7,-20.0/7); } 结果为:2,-2 2.857143,-2.857143 本例中,20/7,-20/7 的结果均为整型,小数全部舍去。而 20.0/7 和-20.0/7 由于有实数 参与运算,因此结果也为实型。 5.求余运算符(模运算符)“%”:双目运算,具有左结合性。要求参与运算的量均为整型。 求余运算的结果等于两数相除后的余数
void main(t printf("%dIn",100%3) 结果 “%”为双目运算,具有左结合性。求余运算符%要求参与运算的量均为整型。本例 输出100除以3所得的余数1。 6算术表达式 算术表达式是由算术运算符和括号连接起来的、符合c语法规则的式子,以下是算术 表达式的例子 ab(a2)/c(x+r)*8-(a+b)/7++isin(x)+sin(y)(++i)-(j++)+(k-) (二)自增1,自减1运算符 自增1运算符记为“+”,其功能是使变量的值自增1。自减1运算符记为“-”,其功能 是使变量值自减1。自增1,自减1运算符均为单目运算,都具有右结合性。可有以下 几种形式: +ii自增1后再参与其它运算 --ii自减1后再参与其它运算 计+i参与运算后,i的值再自增1 i--i参与运算后,i的值再自减1 在理解和使用上容易出错的是+和i-。特别是当它们出现在较复杂的表达式或语句 中时,常常难于弄清,因此应仔细分析 注意:1、自增、自减运算符只能用于变量不能用于常量或表达式 2、自增、自减运算符的结合方向为自右向左。 例如:若i的原值为3则执行语句 printf(“%”-i计+);的结果为-3。(先取出 的值3输出-i的值-3,然后i增值为4) 3、对于计++类表达式c编译系统在处理时自左而右尽可能多的将若干个字符 组成一个运算符。所以它相当于(计++)+j 4、在函数调用时对函数参数的求值顺序是自右而左 例如:若i的初值位3则执行pin%d,%”i+),的结果为4,3 (三)赋值运算符和赋值表达式 简单赋值运算符和表达式,简单赋值运算符记为-”。由“=”连接的式子称为赋值表达 式 其一般形式为:变量=表达式例如: =a+b w=sin(a)+sin(b) y=计+艹-」赋值表达式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右 结合性。因此
12 void main(){ printf("%d\n",100%3); } 结果:1 “%”为双目运算,具有左结合性。求余运算符% 要求参与运算的量均为整型。本例 输出 100 除以 3 所得的余数 1。 6.算术表达式 算术表达式是由算术运算符和括号连接起来的、符合 c 语法规则的式子, 以下是算术 表达式的例子: a+b (a*2)/c (x+r)*8-(a+b)/7 ++i sin(x)+sin(y) (++i)-(j++)+(k--) (二)自增1,自减1运算符 自增 1 运算符记为“++”,其功能是使变量的值自增 1。自减 1 运算符记为“- - ”,其功能 是使变量值自减 1。自增 1,自减 1 运算符均为单目运算,都具有右结合性。可有以下 几种形式: ++i i 自增 1 后再参与其它运算。 - -i i 自减 1 后再参与其它运算。 i++ i 参与运算后,i 的值再自增 1。 i- - i 参与运算后,i 的值再自减 1。 在理解和使用上容易出错的是 i++和 i--。 特别是当它们出现在较复杂的表达式或语句 中时,常常难于弄清,因此应仔细分析。 注意:1、自增、自减运算符只能用于变量不能用于常量或表达式 2、自增、自减运算符的结合方向为自右向左。 例如:若 i 的原值为 3 则执行语句 printf(“%d”,-i++);的结果为-3。(先取出 i 的值 3 输出-i 的值-3,然后 i 增值为 4) 3、对于 i+++j 类表达式 c 编译系统在处理时自左而右尽可能多的将若干个字符 组成一个运算符。所以它相当于(i++)+j 4、在函数调用时对函数参数的求值顺序是自右而左。 例如: 若 i 的初值位 3 则执行 printf(“%d,%d”,i,i++);的结果为 4,3 (三)赋值运算符和赋值表达式 简单赋值运算符和表达式,简单赋值运算符记为“=”。由“= ”连接的式子称为赋值表达 式。 其一般形式为: 变量=表达式 例如: x=a+b w=sin(a)+sin(b) y=i+++--j 赋值表达式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右 结合性。因此
可理解为 a=(b=(c=5)) 如果赋值运算符两边的数据类型不相同,系统将自动进行类型转换,即把赋值号右边 的类型换成左边的类型。具体规定如下 1、实型赋予整型,舍去小数部分。 2、整型赋予实型,数值不变,但将以浮点形式存放,即增加小数部分(小数部分的值 为0)。 3、字符型赋予整型,由于字符型为一个字节,而整型为二个字节,故将字符的 ASCII 码值放到整型量的低八位中,高八位为0或为1视系统而定 4、整型赋予字符型,只把低八位赋予字符量 5、将 unsigned int型数据赋给 long int型变量时,只需将高位补0 6、将非 unsigned型数据赋给长度相同的 unsigned型变量,也是原样照赋。 (四)复合赋值符及表达式 在赋值符“”之前加上其它二目运算符可构成复合赋值符 例如:+=-=,*=,/=,% 构成复合赋值表达式的一般形式为:变量双目运算符=表达式它等效于变量=变量 运算符表达式 例如:a+=5等价于a=a+5x*=y+7等价于x=x+y+7)r%=p等价于r=r%p 复合赋值符这种写法,对初学者可能不习惯,但十分有利于编译处理,能提高编译效 率并产生质量较高的目标代码 (五)逗号运算符和逗号表达式 C语言中逗号“,”也是一种运算符,称为逗号运算符。其功能是把两个表达式连接起 来组成一个表达式,称为逗号表达式 其一般形式为:表达式1,表达式2其求值过程是分别求两个表达式的值,并以表达 式2的值作为整个逗号表达式的值。 说明两点: 1、逗号表达式中的表达式1和表达式2也可以又是逗号表达式 例如:表达式1,(表达式2,表达式3)形成了嵌套情形 因此可以把逗号表达式扩展为以下形式:表达式1,表达式2,…表达式n整个逗号 表达式的值等于表达式n的值 2、程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不 定要求整个逗号表达式的值 3、并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数 表中逗号只是用作各变量之间的间隔符
13 a=b=c=5 可理解为 a=(b=(c=5)) 如果赋值运算符两边的数据类型不相同, 系统将自动进行类型转换,即把赋值号右边 的类型换成左边的类型。具体规定如下: 1、实型赋予整型,舍去小数部分。 2、 整型赋予实型,数值不变,但将以浮点形式存放, 即增加小数部分(小数部分的值 为 0)。 3、字符型赋予整型,由于字符型为一个字节, 而整型为二个字节,故将字符的 ASCII 码值放到整型量的低八位中,高八位为 0 或为 1 视系统而定。 4、整型赋予字符型,只把低八位赋予字符量。 5、将 unsigned int 型数据赋给 long int 型变量时,只需将高位补 0。 6、将非 unsigned 型数据赋给长度相同的 unsigned 型变量,也是原样照赋。 (四)复合赋值符及表达式 在赋值符“=”之前加上其它二目运算符可构成复合赋值符。 例如:+=,-=,*=,/=,%= 构成复合赋值表达式的一般形式为: 变量 双目运算符=表达式 它等效于 变量=变量 运算符 表达式 例如: a+=5 等价于 a=a+5 x*=y+7 等价于 x=x*(y+7) r%=p 等价于 r=r%p 复合赋值符这种写法,对初学者可能不习惯, 但十分有利于编译处理,能提高编译效 率并产生质量较高的目标代码。 (五)逗号运算符和逗号表达式 C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接起 来组成一个表达式, 称为逗号表达式。 其一般形式为: 表达式 1,表达式 2 其求值过程是分别求两个表达式的值,并以表达 式 2 的值作为整个逗号表达式的值。 说明两点: 1、逗号表达式中的表达式 1 和表达式 2 也可以又是逗号表达式。 例如: 表达式 1,(表达式 2,表达式 3) 形成了嵌套情形。 因此可以把逗号表达式扩展为以下形式: 表达式 1,表达式 2,…表达式 n 整个逗号 表达式的值等于表达式 n 的值。 2、程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不一 定要求整个逗号表达式的值。 3、并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数 表中逗号只是用作各变量之间的间隔符
3.2例题 【例题3-】下列哪些是c语言提供的合法的数据关键字 B. signed C.integer D. Char 解析:此题的选项A和D中有一个字母是大写字母,c语言的关键字不允许用大写字 母,所以是不正确的,c也不对,在c语言中,用int而不用 Integer做为整形数据定义 的关键字,只有B是对的, signed是有符号的意思,是c语言中的一个关键字。 答案:B 【例题3-2】下面标识符中,合法的用户标识符为 A.变量a 2ab 解析:标识符只能由字母、数字、下划线三种字符组成。且第一个字符必须为字母或下 划线。A是汉字不是上述三种情况之一,不能用做用户标识符。而B含有加号,加号 不能用做标识符。D是以数字开头,不符合标识符命名规则。C选项是c语言的库函数, 可以做用户标识符 答案:C 【例题3-3】下列属于整形常量的是 A.0X12AB.12XC.-12.D.lE2 解析:十六进制整数是以∝x开头,所以选项B不合法。选项C有小数点所以是实型常 量的十进制表示形式,D是实型常量的指数表示形式。c语言能用来表示整常数的有三 种:十进制、八进制、十六进制。A是整形常量的十六进制表示形式。 答案:A 【例题3-4】下述四项中,合法的c语言整型常量是 A.-087 5LC.(long)l23456D.1.23e+2 解析:选项A中087虽然是以0开头的,但它不是一个八进制数,因为一个八进制数的 数字字符在0—7之间,八进制数前可以带负号。选项C是一个表达式而不是一个常量。 选项D是一个实形常量。选项B是在一个整数后加L构成一个长整形常量。 谷案:B 【例题35】以下不正确的实型常量是() A.=2. B.123E-2 C.-.543 D.2.lE3.5 解析:1、实型常量的十进制表示形式中,小数部分或整数部分可省略,但不能同时省略。 2、在指数形式(fem或im)的表示中f为十进制整数或浮点数,m必须是整数,并且 f和m都不能省略,“+”号可以省略,“-”号不能省略。)观察以上A、B、C三个选项 都是合法实型常量。选项D中指数部分不是整数,是错误的。 谷案 【例题36】若有以下定义和语句
14 3.2 例题 【例题 3-1】下列哪些是 c 语言提供的合法的数据关键字 A. Float B. signed C. integer D. Char 解析:此题的选项 A 和 D 中有一个字母是大写字母,c 语言的关键字不允许用大写字 母,所以是不正确的,c 也不对,在 c 语言中,用 int 而不用 integer 做为整形数据定义 的关键字,只有 B 是对的,signed 是有符号的意思,是 c 语言中的一个关键字。 答案:B 【例题 3-2】下面标识符中,合法的用户标识符为 A.变量 a B. fast+1 c. printf D. 2ab 解析:标识符只能由字母、数字、下划线三种字符组成。且第一个字符必须为字母或下 划线。A 是汉字不是上述三种情况之一,不能用做用户标识符。而 B 含有加号,加号 不能用做标识符。D 是以数字开头,不符合标识符命名规则。C 选项是 c 语言的库函数, 可以做用户标识符。 答案:C 【例题 3-3】下列属于整形常量的是 A.0X12A B.12x C.-12. D.1E2 解析:十六进制整数是以 0x 开头,所以选项 B 不合法。选项 C 有小数点所以是实型常 量的十进制表示形式,D 是实型常量的指数表示形式。c 语言能用来表示整常数的有三 种:十进制、八进制、十六进制。A 是整形常量的十六进制表示形式。 答案:A 【例题 3-4】下述四项中,合法的 c 语言整型常量是 A. -087 B. 5L C. (long)123456 D. 1.23e+2 解析:选项 A 中 087 虽然是以 0 开头的,但它不是一个八进制数,因为一个八进制数的 数字字符在 0—7 之间,八进制数前可以带负号。选项 C 是一个表达式而不是一个常量。 选项 D 是一个实形常量。选项 B 是在一个整数后加 L 构成一个长整形常量。 答案:B 【例题 3-5】以下不正确的实型常量是() A. –2. B.123E-2 C.-.543 D.2.1E3.5 解析:1、实型常量的十进制表示形式中,小数部分或整数部分可省略,但不能同时省略。 2、在指数形式(fem 或 fEm)的表示中,f 为十进制整数或浮点数,m 必须是整数,并且 f 和 m 都不能省略,“+”号可以省略,“-”号不能省略。)观察以上 A、B、C 三个选项 都是合法实型常量。选项 D 中指数部分不是整数,是错误的。 答案:D 【例题 3-6】若有以下定义和语句:
intu=010,v=0x10,w=10 printf("%d, %d, %d", u,v, w) 则结果输出为() A.8,16,10B.10,10,10C.8,8,10D.8,10,10 解析:函数pinf要求三个整形变量u,v,w按十进制形式输出,所以八进制数“010” 要转换成十进制数8,十六进制数0x10要转换成十进制16。 谷案 【例题3-7】下述常量中,哪些是不合法的常量 A.“\12 D.“483” 解析:显然,B和D是字符串常量,A是字符常量。选项A是一个普通的八进制转义 字符, ASCII值为10。B是空字符串。选项D初看起来是一个八进制转义序列。但因 为8超过了八进制范围,系统自动将其识别为4、8和3组成,在输出时显示为“◇ 83”。选项c仅由两个连续的单引号组成,是错误的字符常量 答案:C 【例题38】以下不合法的常量是() B 解析:B选项""是空字符串常量,此串仅占用一个字节。A选项为转义字符。D选项 为字符串常量,而C选项看似为转义字符,但超过了后的八进制的表示范围,是不合法 的 答案:C 【例题39】字符串1”AAA1123xAAt的长度为 B.17 C.14 D.10 解析:c语言对上述问题的处理方法是从左向右尽可能多的将连续的字符组成一个有意 义的项。所以为转义字符”为转义字符输出为”。AAA是三个普通字符。23也是转 义字符。XAA是转义字符。t为一个转义字符。 答案 【例题3-10】下列选项中, )是正确的转义字符。 B."\082 解析:B选项“\”后应为1-3位八进制,但8超过了八进制的表示范围,故是错误的 C选项不是转义字符的表示形式。D选项不是转义字符的正确表示形式。A选项表示十 六进制ef所表示的字符∩ 答案:A 【例题3-11】下面程序段的结果是 inti=65536; printf("%d\n”,n), A.65536B.0C.有语法错误,无出结果D.1 解析:c语言规定,int类型变量占两个字节的存储单元,表示的数值范围为-32768 32767,题目中的i赋值为65536,已超过两个字节所能表示的数值,c语言认为这并
15 int u=010,v=0x10,w=10; printf(“%d,%d,%d”,u,v,w); 则结果输出为( ) A.8,16,10 B. 10,10,10 C. 8,8,10 D. 8,10,10 解析:函数 printf 要求三个整形变量 u,v,w 按十进制形式输出,所以八进制数“010” 要转换成十进制数 8,十六进制数 0x10 要转换成十进制 16。 答案:A 【例题 3-7】下述常量中,哪些是不合法的常量 A.’\12’ B.“ ” C.‘’ D.“\483” 解析:显然,B 和 D 是字符串常量,A 是字符常量。选项 A 是一个普通的八进制转义 字符,ASCII 值为 10。B 是空字符串。选项 D 初看起来是一个八进制转义序列。但因 为 8 超过了八进制范围,系统自动将其识别为’\4’、’8’和’3’组成,在输出时显示为“◇ 83”。选项 c 仅由两个连续的单引号组成,是错误的字符常量。 答案:C 【例题 3-8】以下不合法的常量是() A. ‘\6’ B. "" C.‘\286’ D.”\286” 解析:B 选项""是空字符串常量,此串仅占用一个字节。A 选项为转义字符。D 选项 为字符串常量,而 C 选项看似为转义字符,但超过了\后的八进制的表示范围,是不合法 的。 答案:C 【例题 3-9】字符串”\ \ \ ”AAA \ 1 2 3 \ x AA \ t”的长度为 A.8 B.17 C.14 D.10 解析:c 语言对上述问题的处理方法是从左向右尽可能多的将连续的字符组成一个有意 义的项。所以\\为转义字符\,\”为转义字符输出为”。AAA 是三个普通字符。\123 也是转 义字符。\XAA 是转义字符。 \t 为一个转义字符。 答案:A 【例题 3-10】下列选项中,( )是正确的转义字符。 A.' \ xef' B.' \ 082' C.' xab ' D.' \' 解析:B 选项“\”后应为 1-3 位八进制,但 8 超过了八进制的表示范围,故是错误的。 C 选项不是转义字符的表示形式。D 选项不是转义字符的正确表示形式。A 选项表示十 六进制 ef 所表示的字符∩。 答案:A 【例题 3-11】下面程序段的结果是 int i=65536; printf(“%d\n”, i); A. 65536 B. 0 C. 有语法错误,无出结果 D. 1 解析:c 语言规定,int 类型变量占两个字节的存储单元,表示的数值范围为-32768— —32767,题目中的 i 赋值为 65536,已超过两个字节所能表示的数值,c 语言认为这并