C++中对浮点数的格式化显示

2016-02-19 20:50 21 1 收藏

今天图老师小编给大家精心推荐个C++中对浮点数的格式化显示教程,一起来看看过程究竟如何进行吧!喜欢还请点个赞哦~

【 tulaoshi.com - 编程语言 】


  在许多应用程序领域中,都需要控制小数点后的小数位,但是浮点数对此不能提供直接的支持。怎样对程序中的浮点数据进行"整洁"地格式化呢?在此我们有一个迂回的方法,先把它们转换为字符串,格式化后以文本形式显示出来。
  
   !-- frame contents -- !-- /frame contents --   在日常编程中--包括对话框、关系数据库、金融程序、SMS程序及一切处理数据文件的程序,需要控制小数点后的小数位的情况非常普遍,本文中将要讲解如何用简单的方法来控制小数位,另外,还要揭开字符串及数据精度的一点点小秘密。
  
  问题的引出
  
  如有一个函数,其可接受一个long double参数,并将参数转换为字符串,结果字符串应保留两位小数,例如,浮点值123.45678应该生成"123.45"这样的字符串。表面上看来这是一个意义不大的编程问题,然而,假如真要在实际中派上用场,函数应设计为具有一定弹性,以答应调用者指定小数位数。另外,函数也应该能够处理各种异常情况,如像123.0或123这样的整数。
  在开始之前,先看一下编写"优雅"C++代码时的两句"真言":
  
  "真言"1:无论何时需要格式化一个数值,都应先转换为一个字符串。这样可保证每位数刚好占据一个字符。
  
  "真言"2:在需要转换为字符串时,请使用sstream库。
  
  转换函数的接口非常简洁:第一个参数是需被格式化的数值;第二个参数代表小数点后显示的小数位,且应该具有一个默认值;返回值为一个string类型:
  
  string do_fraction(long double value, int decplaces=3);
  注重,第二个参数代表的小数位数中包括了小数点,因此,两位小数需要默认值为3。
  
  精度问题
  
  当然,第一步是把long double值转换为一个string,使用标准C++库sstream简直是手到擒来。然而,有一件事情必须引起注重,因为某些原因,stringstream对象默认精度为6,而许多程序员错误地把"精度"理解为小数的位数,这是不正确的,精度应指代全部位数。因而,数字1234.56可安全地通过默认精度6来表示,但12345.67会被截断为12345.6。这样的话,假如你有一个非常大的数,如1234567.8,它的结果会静静静地转换为科学记数法:1.23457e+06,这显然不是我们想要的。为避免这样的麻烦,在开始转换之前,应把默认精度设为最大。
  为得到long double能表示的最大位数,可使用limits库:
  
  string do_fraction(long double value, int decplaces=3)
  {
  int prec=numeric_limitslong double::digits10; // 18
  ostringstream out;
  out.precision(prec);//覆盖默认精度
  outvalue;
  string str= out.str(); //从流中取出字符串 数值现在存储在str中,等待格式化。 小数点的位置
  
  要进行格式化,首先要确定小数点的位置,假如小数位多于decplaces,do_fraction()会删除多余的。
  
  要定位小数位,可使用string::find(),在STL算法中使用了一个常量来代表"数值未找到",在字符串中,这个常量为string::npos:
  
  char DECIMAL_POINT='.'; // 欧洲用法为','
  
  size_t n=str.find(DECIMAL_POINT);
  if ((n!=string::npos)//是否有小数点呢?
  {
  //检查小数的位数
  }
  假如没有小数点,函数直接返回字符串,否则,函数将继续检查小数位是否多于decplaces。假如是,小数部分将会被截断:
  
  size_t n=str.find(DECIMAL_POINT);
  if ((n!=string::npos)//有小数点吗?
  &&(str.size() n+decplaces)) //后面至少还有decplaces位吗?
  
  //在小数decplaces位之后写入nul
  str[n+decplaces]='

来源:http://www.tulaoshi.com/n/20160219/1624643.html

延伸阅读
现在几乎是每个家庭都购买了电脑。电脑对于我们来说,也成为了很重要的设备。当我们购买了电脑之后,就需要存储文件。如果是直接存储文件,没有对存储的路径进行设置的话,就会默认的存储到C盘。久而久之,C盘的空间就会满了。这个时候,电脑的使用也会出现问题。人们就会对C盘进行格式化。下面介绍一下C盘无法格式化的问题。 c盘无法格式...
标签: 电脑入门
我本来用的XP装在C盘的,是FAT32格式 现在又装了个 Windows7系统 在E盘 现在我想把C盘格了把Windows7装在C,可是我把Windows XP删除了以后才发现格不了...但现在不格也不能把Windows7装在C请问怎么格? 有个Windows 7安装工具 和光盘安装一样 把镜像解压到D盘或者D盘的根目录 然后运行 Windows 7 安装工具 重启电脑 进入安装界面 格式化C盘然后...
  1. 格式化 fdformat /dev/fd0H1440 2. 作档案系统 mkfs -t ext2 /dev/fd0 
DiskGenius如何格式化分区(快速格式化) 分区建立后,必须经过格式化才能使用。本软件目前支持NTFS、FAT32、FAT16、FAT12等文件系统的格式化。 首先选择要格式化的分区为当前分区,然后点击工具栏按钮格式化,或点击菜单分区 - 格式化当前分区项,也可以在要格式化的分区上点击鼠标右键并在弹出菜单中选择格式化当前分区项。程序会弹...
这是一个注册EXE,OBJ,BIN三种类型文件,当其被RichEdit打开时会自动转换为16进制显示的例子 -------------------------------------------------------------------------------- 步骤: 第一:要从TCoriversion派生出一个新类 第二:重载CorrvertReadStream函数 第三:在主窗体的OnCreate函数中登记文件类型。用...

经验教程

751

收藏

29
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部