#include
int main()
{
int a=10;float b=1.28,c;
c=a*b;
printf ("%d",c);
return 0;
}
为什么结果是 -2147483648请按任意键继续. . .
程序本身有问题,要这么写
#include <stdio.h>
int main()
{
int a=10;
float b=1.28,c=0;
c=a*b;
printf("%d",*(int *)(&c));
}
在我这里是1095552204
用二进制表示是 01000001 01001100 11001100 11001100
其中0是符号位,10000010是指数位=130,减去127=3,(0.)1001100 11001100 11001100 是尾数 = 0.5999999046325684
结果就是1.6x2的3次方,也就是1.6x8=12.8,和你的结果一样。
参考:
https://www.cnblogs.com/zhugehq/p/5918599.html
http://tool.oschina.net/hexconvert
https://tool.lu/coderunner/
printf函数不能根据你传入的是什么类型的变量而改变格式。它只是根据你的格式来读这个变量。所以你让它以%d输出它就是以整数来读入这个变量,整数类型的编码和浮点类型的编码是非常不同的,于是就出现了这样的问题。
浮点数保存的格式与整数不同,参考IEEE754标准,要输出浮点数,用printf("%f",c);
%d 所给出的是整形,%f 是浮点数 c的值为浮点数类型,所以你应该用 %f 的浮点型输出c,你可以试试浮点数输出c
printf("%d",)输出的是整数的格式,你上面用浮点数进行计算输出,肯定会溢出,你可以试试,%f输出。
c是float类型,要用相应类型:
#include <stdio.h>
int main()
{
int a = 10; float b = 1.28, c;
c = a*b;
printf("%f", c);
return 0;
}
printf("%f", c);