3.1 混合运算要小心

【例3.1】分析下面程序的输出结果。


#include <stdio.h>
void main
()
{
     double a=2
,b=6
;
     int c=2
,d=6
;
     printf
("%f\n"
,a/b
);          //1
     printf
("%f\n"
,2/6
);          //2
     printf
("%f\n"
,2./6
);          //3
     printf
("%f\n"
,(double
)c/d
);     //4
     printf
("%f\n"
,(double
)(c/d
));     //5
     printf
("%f\n"
,(double
)(c/b
));     //6
     printf
("%d\n"
,2/6
);          //7
     printf
("%f\n"
,c/b
);          //8
}
  

第2条语句的“2/6”与第7条语句的“2/6”是一样的,都是两个整数相除,结果为0,只是第2条语句用实数输出,为0.000000,第7条语句用整数输出,为0。第5条输出语句只是将整数“2/6”的结果转换为实数,整数相除的结果为0,当然输出与第2条语句一样。

第6条语句对“c/b”的结果进行转换是多余的,因为“c/b”已经是混合运算,自动实现转换,与第8条语句等效。第3条语句也是实数和整数的混合运算,它们的结果都与第1条语句的结果一样,均输出0.333333。程序的输出为


0.333333
0.000000
0.333333
0.333333
0.000000
0.333333
0
0.333333
  

整型、单精度、双精度型数据可以混合运算,字符型数据可以与整型数据通用。因此,整型、实型(包括单、双精度)、字符型数据间可以混合运算。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算。转换规则是:字符型必须先转换为整数,short型转换为int型,float型数据在运算时一律先转换成双精度型;int型与double型数据进行运算,先将int型数据转换成double型,结果为double型;同理,int型与long型数据进行运算,先将int型转换成long型,结果为long型。

【例3.2】演示字符和整数的运算程序。


#include <stdio.h>
void main
()
{
       char a='a'
;   int i=97
;
       printf
("%c %c %c\n"
,a
,(a+1
),(a+2
));
       printf
("%c %c %c\n"
,i
,(i+1
),(i+2
));
       printf
("%d %d %d\n"
,a
,(a+1
),(a+2
));
}
  

在VC中,第1条语句与下面的语句


printf
("%c %c %c\n"
,a
,a+1
,a+2
);
  

是等效的。之所以不用这种形式,是因为有的C编译器对“a+1”和“(a+1)”的处理方式不一样,效果也就不一样。根据混合运算规则,可以分析出程序输出的结果如下。


a b c
a b c
97 98 99
  

【例3.3】分析下面程序中的错误。


#include <stdio.h>
void main
()
{
      int a=97
; double b=25
;
      printf
("%d\n"
,a%b
);
}
  

运算符%只适用于整数,需要对b强制转换,即“a%(int)b”,变成97%25=22。

注意不能将形如“b=25”的b误认为整数,它是25.000000,不符合求余的运算要求。

《C语言解惑》