免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2515 | 回复: 3
打印 上一主题 下一主题

求助关于float值精度的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-01-24 22:16 |只看该作者 |倒序浏览
  1. #include <cstdio>;


  2. int main()
  3. {
  4.         float f1 = 3.402823466e+38f;
  5.         printf( "f1 = %.9e\n", f1 );

  6.         float f2 = 3.302823466e+38f;
  7.         printf( "f2 = %.9e\n", f2 );

  8.         float f3 = 3.402823466e+35f;
  9.         printf( "f3 = %.9e\n", f3 );

  10.         float f4 = 3.40282346e+38f;
  11.         printf( "f4 = %.8e\n", f4 );

  12.         return 0;
  13. }
复制代码


运行结果:
  1. f1 = 3.402823466e+038
  2. f2 = 3.302823480e+038
  3. f3 = 3.402823435e+035
  4. f4 = 3.40282347e+038
复制代码


我从FLOAT.H中找到:
  1. #define FLT_MAX         3.402823466e+38F        /* max value */
复制代码

即上面代码中f1是float型的最大值,它的打印信息是正确的,可是f2,f3,f4都是小于f1的,为什么反而打印不对正确的信息呢?

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
2 [报告]
发表于 2005-01-25 08:33 |只看该作者

求助关于float值精度的问题

float只能保证7位的精度
因为有10进制转化为2进制的问题,FLT_MAX刚好可以表示为二进制数,所以能正确显示,这没什么奇怪的。

论坛徽章:
0
3 [报告]
发表于 2005-01-25 10:52 |只看该作者

求助关于float值精度的问题

原帖由 "yuxh" 发表:
float只能保证7位的精度
因为有10进制转化为2进制的问题,FLT_MAX刚好可以表示为二进制数,所以能正确显示,这没什么奇怪的。


只是显示的问题?或者是存入内存时精度就已经丢失?

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
4 [报告]
发表于 2005-01-25 11:01 |只看该作者

求助关于float值精度的问题

存入的时候精度就丢失了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP