为什么C语言中int i=3,j=5;float x=2.5;double y=5.0;表达式i-=j*=x+y的值不是-34.5而是-34?

如果有取整的运算符号,那么是哪个起到了取整的作用?还有哪些运算符有取整作用?

不是运算符取整,之所以取整的原因是,类型转换!

数据类型的转换一般分为隐含转换和强制转换两种;
隐含转换
算术运算符 关系运算符 逻辑运算符赋值运算符等二元运算符要求两个运算符的类型一致,算术运算 关系运算中参与运算的类型不一致时要进行隐含转换,原则是将低类型转化成高类型(类型越高数据精度越高,double>float>unsigned long>long >int>short>char>)这种转化是电脑自动完成,是安全的,数据精度没有损失;
强制转换
一般涉及到将高类型转化成低类型时使用,不安全,可能在精度的损失,有两种方法
1类型说明符(表达式)//c++强制转化符号
2(类型说明符)表达式 //c强制转化符号;
如 float z=7.56;
int a;
a=int(z);或a=(int)z;

i-=j*=x+y表达式分解如下:
double tmp1 = (double)x + y;
j = int( (double)j * tmp1 ); // j =int( 5.0 *7.5) =37
i-=j; // i = 3 - 37 = -34;
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-12-31
答案在j*=这里,要赋值给j,必然要进行强制转换成整型,即由j*=7.5的结果j=37
i-=j,i=-34
第2个回答  2011-12-31
i-=j*=x+y
===>
i=i-(j*(x+y)),最后因为i是整数,自动取整舍去小数追问

i是整形没错,不过在运算过程中已经转换成double类型啦,表达式的值的类型不应该是最高的级别double形吗?那么怎么会是整数呢?

第3个回答  2011-12-31
就是-34.5追问

但是答案是-34.5···确定吗?

追答

确定的,你可以看下C语言的强制转化一章

相似回答