C++中怎样对程序中的浮点数据进行“整齐”地格式化
本篇内容介绍了“C++中怎样对程序中的浮点数据进行“整齐”地格式化”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
下面进行详细说明在C++中怎样对程序中的浮点数据进行“整齐”地格式化呢?在此我们有一个迂回的方法,先把它们转换为字符串,格式化后以文本形式显示出来,我相信这都是一些技术人员的头疼的问题。
如有C++中有一个函数,其可接受一个long double参数,并将参数转换为字符串,结果字符串应保留两位小数,例如,浮点值123.45678应该生成“123.45”这样的字符串。表面上看来这是一个意义不大的编程问题,然而,如果真要在实际中派上用场,函数应设计为具有一定弹性,以允许调用者指定小数位数。另外,函数也应该能够处理各种异常情况,如像123.0或123这样的整数。
在开始之前,先看一下编写“优雅”C++代码时的两句“真言”:
“真言”1:无论何时需要格式化一个数值,都应先转换为一个字符串。这样可保证每位数刚好占据一个字符。
“真言”2:在需要转换为字符串时,请使用<sstream>库。
转换函数的接口非常简洁:***个参数是需被格式化的数值;第二个参数代表小数点后显示的小数位,且应该具有一个默认值;返回值为一个string类型:
”,但能达到目的就行。以下是do_fraction()的完整代码: string do_fraction(long double value, int decplaces=3){ ostringstream out; int prec= numeric_limits<long double>::digits10; // 18 out.precision(prec);//覆盖默认精度 out<<value; string str= out.str(); //从流中取出字符串 size_t n=str.find(DECIMAL_POINT); if ((n!=string::npos) //有小数点吗? && (str.size()> 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<long double>::digits10; // 18 out.precision(prec);//覆盖默认精度 out<<value; string str= out.str(); //从流中取出字符串 size_t n=str.find(DECIMAL_POINT); if ((n!=string::npos) //有小数点吗? && (str.size()> n+decplaces)) //后面至少还有decplaces位吗? {str[n+decplaces]='\0';//覆盖***个多余的数 } str.swap(string(str.c_str()));//删除nul之后的多余字符 return str;
“C++中怎样对程序中的浮点数据进行“整齐”地格式化”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341