iTalent12 2021-10-12 10:52 采纳率: 100%
浏览 38
已结题

为什么用%d打印出的浮点数不符合我的预期?

刚学C语言数据的存储,了解了数据的存储格式,便出现了以下问题,希望帮我解答下;
当我定义一个float型变量a时,假设a=9.0,则a在32位系统中以浮点型格式存储为0100 0001 0001 0000 0000 0000 0000 0000,此时我用整型的格式去打印这个数,我预计程序应该是将该内存取出并以整型的方式去计算,结果应该是1091567616,但实际结果却是0;
代码如下:此代码输出为0;

int main()
{
    float b = 9.0;
    //0100 0001 0001 0000 0000 0000 0000 0000
    printf("%d\n", b);
    return 0;
}

如果我把代码写成这样,结果又与我预期相符合,下列代码输出为1091567616;

int main()
{
    float b = 9.0;
    //0100 0001 0001 0000 0000 0000 0000 0000
    int* pb = (int*)&b;
    printf("%d", *pb);
    return 0;
}

这两个代码差别在哪,以及为什么第一个代码的执行结果和我的预期不相同?

  • 写回答

3条回答 默认 最新

查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月20日
  • 已采纳回答 10月12日
  • 创建了问题 10月12日

悬赏问题

  • ¥15 VB6可以成功读取的文件,用C#读不了
  • ¥15 如何使用micpyhon解析Modbus RTU返回指定站号的湿度值,并确保正确?
  • ¥15 C++ 句柄后台鼠标拖动如何实现
  • ¥15 有人会SIRIUS 5.8.0这个软件吗
  • ¥30 comsol仿真等离激元
  • ¥15 静电纺丝煅烧后如何得到柔性纤维
  • ¥15 (标签-react native|关键词-镜像源)
  • ¥100 照片生成3D人脸视频
  • ¥15 伪装视频时长问题修改MP4的时长问题,
  • ¥15 JETSON NANO