标题:float尾数位数的含义???
只看楼主
sharplong
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:122
专家分:121
注 册:2017-3-27
结帖率:85.71%
已结贴  问题点数:20 回复次数:5 
float尾数位数的含义???
看书中有一段内容讲字符常量,在头文件float.h中,FLT_MANT_DIG代表了float类型的尾数位数。
请问,这个位数位数指的什么??
2017-04-11 15:52
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
知道“科学计数法”和“有效位”的概念吗?
比如 -8.964E+23
它的有效位有 4 位

以上是十进制形式的科学计数法
二进制形式同样,比如 1.010011000E+33

float 就是以二进制形式的科学计数法表示的
FLT_MANT_DIG 是指示float的 二进制形式的科学计数法 的有效位位数
2017-04-11 16:02
sharplong
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:122
专家分:121
注 册:2017-3-27
得分:0 



[此贴子已经被作者于2017-4-11 16:17编辑过]


跟据科学研究呢,拥有一个良好的头像呢,有助于提高帖子关注度,和被友好对待的可能性:)准确来说呢,其实,我是一个演员....和兼职汽车维修员
2017-04-11 16:15
sharplong
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:122
专家分:121
注 册:2017-3-27
得分:0 
回复 2楼 rjsp
那么二进制1.11111E+22的有效位数为6?如果FLT_MANT_DIG为23的话,表示float型有效位数最长为23,
1.1111 1111 1111 1111 11E+12(23位有效数字)这样是可以精确表示的,如果超过23位就不能精确表示。对吗?

跟据科学研究呢,拥有一个良好的头像呢,有助于提高帖子关注度,和被友好对待的可能性:)准确来说呢,其实,我是一个演员....和兼职汽车维修员
2017-04-11 16:16
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:20 
如果FLT_MANT_DIG为23的话
------ FLT_MANT_DIG为24。float的尾数有23bits,加上一个隐含位,是24个

如果超过23位就不能精确表示。对吗?
------ 我不知道“精确”是什么意思,为了避免使你误解,我只能说float中存储有效数的就是23bits
2017-04-11 16:26
sharplong
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:122
专家分:121
注 册:2017-3-27
得分:0 
回复 5楼 rjsp
谢谢,结贴了。

跟据科学研究呢,拥有一个良好的头像呢,有助于提高帖子关注度,和被友好对待的可能性:)准确来说呢,其实,我是一个演员....和兼职汽车维修员
2017-04-11 17:16



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-475998-1-1.html




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

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