C语言中的变量自动转换问题

#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);