下面进行详细说明在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;
【编辑推荐】