不是运算符取整,之所以取整的原因是,类型转换!数据类型的转换一般分为隐含转换和强制转换两种;隐含转换算术运算符 关系运算符 逻辑运算符赋值运算符等二元运算符要求两个运算符的类型一致,算术运算 关系运算中参与运算的类型不一致时要进行隐含转换,原则是将低类型转化成高类型(类型越高数据精度越高,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) =37i-=j; // i = 3 - 37 = -34;
i-=j*=x+y===>i=i-(j*(x+y)),最后因为i是整数,自动取整舍去小数 追问 i是整形没错,不过在运算过程中已经转换成double类型啦,表达式的值的类型不应该是最高的级别double形吗?那么怎么会是整数呢?