c开发教程:c中对浮点数的格式化显示

c开发教程:c中对浮点数的格式化显示

ID:35199233

大小:17.55 KB

页数:6页

时间:2019-03-21

c开发教程:c中对浮点数的格式化显示_第1页
c开发教程:c中对浮点数的格式化显示_第2页
c开发教程:c中对浮点数的格式化显示_第3页
c开发教程:c中对浮点数的格式化显示_第4页
c开发教程:c中对浮点数的格式化显示_第5页
资源描述:

《c开发教程:c中对浮点数的格式化显示》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、www.cdtedu.com达内教育—中国IT培训领导品牌C++开发教程:C++中对浮点数的格式化显示在日常编程中--包括对话框、关系数据库、金融程序、SMS程序及一切处理数据文件的程序,需要控制小数点后的小数位的情况非常普遍,本文中将要讲解如何用简单的方法来控制小数位,另外,还要揭开字符串及数据精度的一点点小秘密。问题的引出如有一个函数,其可接受一个longdouble参数,并将参数转换为字符串,结果字符串应保留两位小数,例如,浮点值123.45678应该生成“123.45”这样的字符串。表面上看来这是一个意义不大的编程问题,

2、然而,如果真要在实际中派上用场,函数应设计为具有一定弹性,以允许调用者指定小数位数。另外,函数也应该能够处理各种异常情况,如像123.0或123这样的整数。在开始之前,先看一下编写“优雅”C++代码时的两句“真言”:“真言”1:无论何时需要格式化一个数值,都应先转换为一个字符串。这样可保证每位数刚好占据一个字符。“真言”2:在需要转换为字符串时,请使用库。www.cdtedu.com达内教育—中国IT培训领导品牌转换函数的接口非常简洁:第一个参数是需被格式化的数值;第二个参数代表小数点后显示的小数位,且应该具有

3、一个默认值;返回值为一个string类型:stringdo_fraction(longdoublevalue,intdecplaces=3);注意,第二个参数代表的小数位数中包括了小数点,因此,两位小数需要默认值为3。精度问题当然,第一步是把longdouble值转换为一个string,使用标准C++库简直是手到擒来。然而,有一件事情必须引起注意,因为某些原因,stringstream对象默认精度为6,而许多程序员错误地把“精度”理解为小数的位数,这是不正确的,精度应指代全部位数。因而,数字1234.56可安全

4、地通过默认精度6来表示,但12345.67会被截断为12345.6。这样的话,如果你有一个非常大的数,如1234567.8,它的结果会静悄悄地转换为科学记数法:1.23457e+06,这显然不是我们想要的。为避免这样的麻烦,在开始转换之前,应把默认精度设为最大。为得到longdouble能表示的最大位数,可使用库:stringdo_fraction(longdoublevalue,intdecplaces=3){intprec=numeric_limits::digits10;//18os

5、tringstreamout;out.precision(prec);//覆盖默认精度www.cdtedu.com达内教育—中国IT培训领导品牌out<

6、charDECIMAL_POINT='.';//欧洲用法为','size_tn=str.find(DECIMAL_POINT);if((n!=string::npos)//是否有小数点呢?{//检查小数的位数}如果没有小数点,函数直接返回字符串,否则,函数将继续检查小数位是否多于decplaces。如果是,小数部分将会被截断:www.cdtedu.com达内教育—中国IT培训领导品牌size_tn=str.find(DECIMAL_POINT);if((n!=string::npos)//有小数点吗?&&(str.size()>

7、n+decplaces))//后面至少还有decplaces位吗?//在小数decplaces位之后写入nulstr[n+decplaces]='';最后一行覆盖了多余的小数位,它使用了常量来截断字符串,要注意,string对象的数据可以包含nul字符;而字符串的实际长度由size()的返回值决定。因此,你不能假定字符串已被正确地格式化,换句话来说,如果在str中原来为“123.4567”,在插入常量之后,它变成了“123.457”,为把str缩减为“123.45”,一般可使用自交换的方法:str.swap(st

8、ring(str.c_str()));//删除nul之后的多余字符那它的原理是什么呢?函数string::c_str()返回一个constchar*代表此字符串对象,而这个值被用作一个临时string对象的初始化值,接着,临时对象又被用作str.swap()的参

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。