神舟NO.10
2019-01-24 20:51
采纳率: 72.2%
浏览 716

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

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

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

7条回答 默认 最新

  • threenewbee 2019-01-25 00:39
    已采纳

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

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

    #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/

    打赏 评论
  • _ZGq 2019-01-24 21:08

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

    打赏 评论
  • 爱青天媛 2019-01-24 22:26

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

    打赏 评论
  • LLinz_ 2019-01-24 23:27

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

    打赏 评论
  • JesonKing1 2019-01-25 09:34

    printf("%d",)输出的是整数的格式,你上面用浮点数进行计算输出,肯定会溢出,你可以试试,%f输出。

    打赏 评论
  • 白色一大坨 2019-01-25 10:04

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

    #include <stdio.h>
    int main()
    {
        int a = 10; float b = 1.28, c;
        c = a*b;
        printf("%f", c);
        return 0;
    }
    
    打赏 评论
  • zhanglaoke 2019-01-25 11:14

    printf("%f", c);

    打赏 评论

相关推荐 更多相似问题