我们知道,C一般在运算时,若参与运算量的类型不同,为了保证数据精度不丢失,会先转换成同一类型,然后进行运算(如int*float=float,int*double=double)
如下,在printf函数中4*0.5本应自动转换4为4.0进行运算,结果本应该为2.0,但以%d控制符输出时结果为什么是0呢
#include<stdio.h>
int main(){
int m;
m=4;
printf("%f %d\n",m*0.5,m*0.5);
return 0;
}
输出: 2.000000 0
printf函数中则不会进行类型转换,它是按照%d,%f等控制字符提示的格式从内存中读出你所提供的元素的值,在C语言中,int类型是32bit,而float一般是64bit。
而4*0.2的结果会被强制转化为2.000000(浮点型),用%f读取自然可以正常输出,即完全读取0000 0000 0000 0010;而%d读取只会读区低的8个位,即0000 0000,所以输出0。