当前位置:  编程技术>c/c++/嵌入式

基于C++浮点数(float、double)类型数据比较与转换的详解

    来源: 互联网  发布时间:2014-10-14

    本文导语:  浮点数在内存中的存储机制和整型数不同,其有舍入误差,在计算机中用近似表示任意某个实数。具体的说,这个实数由一个整数或定点数(即尾数)乘以某个基数(计算机中通常是2)的整数次幂得到,这种表示方法类似于...

浮点数在内存中的存储机制和整型数不同,其有舍入误差,在计算机中用近似表示任意某个实数。具体的说,这个实数由一个整数或定点数(即尾数)乘以某个基数(计算机中通常是2)的整数次幂得到,这种表示方法类似于基数为10的科学记数法。
所以浮点数在运算过程中通常伴随着因为无法精确表示而进行的近似或舍入。但是这种设计的好处是可以在固定的长度上存储更大范围的数。
1、将字符串转换为float、double过程存在精度损失,只是float、double各自损失的精度不相同而已
std::string str="8.2";
float cc=atof(str.c_str());  //cc的值为8.1999998
std::string str="8.2";
double cc=atof(str.c_str());  //cc的值为8.1999999999999993
2、将float、double转换为字符过程中可能存在精度损失,但是通过%.8lf可以规避
(1)float小数点前后加起来有效数字只有6位。当给定的float有效数在6位以内转换为字符不会丢失精度,当有效位数大于6位就会存在精度丢失
//精度没有丢失
char buf[100]={''};
float aa=8000.25;
sprintf(buf,"%f",aa);   //8000.250000
//精度没有丢失
char buf[100]={''};
float aa=8.00025;
sprintf(buf,"%f",aa);   buf = 8.000250
//精度丢失,存在误差
char buf[100]={''};
float aa=8000.251;
sprintf(buf,"%f",aa);  //8000.250977
//精度丢失,存在误差此时使用.8lf也无效
char buf[100]={''};
float aa=8000.251;
sprintf(buf,"%.8lf",aa); //8000.25097656
(2)double小数前后加起来的有效数字只有16位,当给定的double有效数在16位以内转换为字符串不会丢失精度,当有效位数大于16位湖影公寓存在精度丢失
存在误差
char buf[100]={''};
double aa=121.437565871234012;
sprintf(buf,"%.20lf",aa); //121.43756587123401000000
//没有误差
char buf[100]={''};
double aa=8000.256165;
sprintf(buf,"%.8lf",aa);
std::cout

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请问斑竹,是不是,专家分越高提问时能给的点数就越多
  • 怎么样四舍五入浮点数?
  • 求救:java里如何取整一个浮点数(不做四舍五入)
  • 如何每次读取一行浮点数?
  • linux下如何计算8字节双精度浮点数double?
  • qt fedora10编译 centos4.5报浮点数例外
  • 如何使程序(字符界面)接受用户输入的一个浮点数,并把他的整数部分和小数部分分别输出。
  • 请教有关用atof()将字符串转换为浮点数的误差问题
  • PHP浮点数的问题探讨
  • python中精确输出JSON浮点数的方法
  • 如何将一个数字的字符串(由:Request.getParameter("...")得到)转换成为浮点数:float 型
  • 将字符窜转化成浮点数问题,测试正确就给分
  • 关于jsp里的浮点数位数的问题(急!!!)
  • 怎样将字符串转换为浮点数?
  • 请问如何输入,输出整数,字符,浮点数?
  • php sprintf函数用法 php浮点数格式
  • php浮点数精度用法分析
  • php的sprintf函数的用法 控制浮点数格式
  • 正则表达式:关于汉字和浮点数的验证!
  • php中float(浮点数)比较的问题


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3