C++中怎样对程序中的浮点数据进行“整齐”地格式化
本篇内容介绍了“C++中怎样对程序中的浮点数据进行“整齐”地格式化”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联是一家专业提供洞口企业网站建设,专注与成都做网站、网站设计、H5页面制作、小程序制作等业务。10年已为洞口众多企业、政府机构等服务。创新互联专业网络公司优惠进行中。
下面进行详细说明在C++中怎样对程序中的浮点数据进行“整齐”地格式化呢?在此我们有一个迂回的方法,先把它们转换为字符串,格式化后以文本形式显示出来,我相信这都是一些技术人员的头疼的问题。
如有C++中有一个函数,其可接受一个long double参数,并将参数转换为字符串,结果字符串应保留两位小数,例如,浮点值123.45678应该生成“123.45”这样的字符串。表面上看来这是一个意义不大的编程问题,然而,如果真要在实际中派上用场,函数应设计为具有一定弹性,以允许调用者指定小数位数。另外,函数也应该能够处理各种异常情况,如像123.0或123这样的整数。
在开始之前,先看一下编写“优雅”C++代码时的两句“真言”:
“真言”1:无论何时需要格式化一个数值,都应先转换为一个字符串。这样可保证每位数刚好占据一个字符。
“真言”2:在需要转换为字符串时,请使用
转换函数的接口非常简洁:***个参数是需被格式化的数值;第二个参数代表小数点后显示的小数位,且应该具有一个默认值;返回值为一个string类型:
”,但能达到目的就行。以下是do_fraction()的完整代码: string do_fraction(long double value, int decplaces=3){ ostringstream out; int prec= numeric_limits::digits10; // 18 out.precision(prec);//覆盖默认精度 out< n+decplaces)) //后面至少还有decplaces位吗? {str[n+decplaces]='\0';//覆盖***个多余的数 } str.swap(string(str.c_str()));//删除nul之后的多余字符 return str;
那它的原理是什么呢?函数string::c_str()返回一个const char *代表此字符串对象,而这个值被用作一个临时string对象的初始化值,接着,临时对象又被用作str.swap()的参数,swap()会把值“123.45”赋给str。一些老一点的编译器不支持默认模板参数,可能不会让swap()通过编译,如果是这样的话,使用手工交换来代替:
”,但能达到目的就行。以下是do_fraction()的完整代码: string do_fraction(long double value, int decplaces=3){ ostringstream out; int prec= numeric_limits::digits10; // 18 out.precision(prec);//覆盖默认精度 out< n+decplaces)) //后面至少还有decplaces位吗? {str[n+decplaces]='\0';//覆盖***个多余的数 } str.swap(string(str.c_str()));//删除nul之后的多余字符 return str;
“C++中怎样对程序中的浮点数据进行“整齐”地格式化”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
网页标题:C++中怎样对程序中的浮点数据进行“整齐”地格式化
转载源于:http://myzitong.com/article/igsggg.html