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

#include
int main()
{
int a=10;float b=1.28,c;
c=a*b;
printf ("%d",c);
return 0;
}
为什么结果是 -2147483648请按任意键继续. . .

7个回答

<- 如果问题得到解决,请点这里的采纳

程序本身有问题,要这么写

#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",)输出的是整数的格式,你上面用浮点数进行计算输出,肯定会溢出,你可以试试,%f输出。

printf("%f", c);

printf函数不能根据你传入的是什么类型的变量而改变格式。它只是根据你的格式来读这个变量。所以你让它以%d输出它就是以整数来读入这个变量,整数类型的编码和浮点类型的编码是非常不同的,于是就出现了这样的问题。

浮点数保存的格式与整数不同,参考IEEE754标准,要输出浮点数,用printf("%f",c);

%d 所给出的是整形,%f 是浮点数 c的值为浮点数类型,所以你应该用 %f 的浮点型输出c,你可以试试浮点数输出c

c是float类型,要用相应类型:

#include <stdio.h>
int main()
{
    int a = 10; float b = 1.28, c;
    c = a*b;
    printf("%f", c);
    return 0;
}
phenix2009
白色一大坨 回复caozhy: 点错啦,又按回去了
12 个月之前 回复
caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 别光点反对啊,我的回答哪里不对,请指教
12 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问