| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 5251 人关注过本帖
标题: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
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册: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
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册: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
快速回复:float尾数位数的含义???
数据加载中...
 
   



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

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