| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1643 人关注过本帖
标题:这个a.f为什么等于0.00000
只看楼主 加入收藏
see235959850
Rank: 2
等 级:论坛游民
帖 子:380
专家分:29
注 册:2016-12-21
结帖率:100%
收藏
 问题点数:0 回复次数:5 
这个a.f为什么等于0.00000
程序代码:
#include<stdio.h>
union Date
{
    int i;
    char ch;
    float f;
};

int main()
{
    union Date a;
    a.i = 97;
    printf("%d\n%c\n%f\n", a.i, a.ch, a.f);
    return 0;
}
搜索更多相关主题的帖子: color 
2017-02-01 21:48
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:0 
这是因为它们共同一个内存,所以和float在内存中的存储模式有关。
具体的你自己查下float类型在内存中是如何存放的知识看看
2017-02-01 23:12
炎天
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:桃花岛
等 级:贵宾
威 望:29
帖 子:1218
专家分:4986
注 册:2016-9-15
收藏
得分:0 
回复 2楼 linlulu001
好久不见,

早知做人那么辛苦!  当初不应该下凡
2017-02-01 23:20
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:0 
回复 3楼 炎天
你好,好久不见。
2017-02-01 23:26
see235959850
Rank: 2
等 级:论坛游民
帖 子:380
专家分:29
注 册:2016-12-21
收藏
得分:0 
看着回答好高深,其实啥也不懂,都是抄答案的,噗
2017-02-02 08:36
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
二楼答主的回答是切题的,建议题主看下这个:http://blog.
尽管我也非专业,表示还是能看懂二楼答主及上述链接的解答,就楼主示例,我理解如下:
a.i、a.ch、a.f共用存储区,因此他的内存数据相同。现a.i=97,在存储区的二进制表示为a.i=00000000 00000000 00000000 01100001(0x00000061),因此根据IEEE 754规则,a.f浮点数的二进制数值应该是1.0000000 00000000 01100001*2^-127,小数点后面127个0,这个数实在太小了,%f格式实在无法显示到这个精度,只能用约等于0表示。
实际上题主如果将显示格式调整为%e的格式(printf("%d\n%c\n%e\n", a.i, a.ch, a.f);),还是能看到这个数的,这个数据的十进制值为:1.35926e-43
2017-02-02 11:30
快速回复:这个a.f为什么等于0.00000
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.033991 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved