double型转换成string型

题目描写叙述:
如有一个函数。其可接受一个long double參数,并将參数转换为字符串。结果字符串应保留两位小数,比如,浮点值123.45678应该生成“123.45”这种字符串。表面上看来 这是一个意义不大的编程问题,然而。假设真要在实际中派上用场。函数应设计为具有一定弹性,以同意调用者指定小数位数。另外,函数也应该可以处理各种异常 情况,如像123.0或123这种整数。
转换函数接口:string do_fraction(long double value, int decplaces = 3)
题目分析:
经验之谈:①不管何时须要格式化一个数值。都应该先转换为一个字符串,这样可保证每位数刚好占领一个字符。②须要转化为字符串时候,能够考虑使用库函数
使用库函数将long double值转化为一个string应该非常easy,可是须要注意以下几个问题:
1)精度问题
由于stringstream对象默认精度为6。(这里须要强调一个精度,老式指的是小数位数,新式应该指的是所有位数),这就会有出现一个问题:假设很大的数,比如123456789.9,它就会转化为科学计数法,这显然不是我们须要的,所以我们使用库函数和转换之前,必须先把默认的精度设为最大
2)小数点位置问题
定位小数位使用string::find
在STL算法中使用一个常量来代表“数值未找到”,字符串中是string::npos
由于我们设定了小数点最大位数decplacea。所以我们要检查小数点位数。假设小于它。那么直接返回字符串。否则小数部分多余的要被截去。

截断字符串的方法:通常使用\0
插入变量\0之后,怎样截去后面的字符。一般採用自交换
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
參考代码:

string do_fraction(long double value, int decplaces = 3)
{
    ostringstream out;
    int prec = numeric_limits::digits10; //18 注意须要加上头文件#include<limits>
    out.precision(prec); //覆盖默认精度

    //从流中取出字符串
    string str = out.str();

    //推断是否有小数点。且还有decpalces位
    size_t n = str.find(DECIMAL_POINT);
    if((n != string::npos) && (str.size() > n + decplaces)) 
    {
        str[n + decplaces] = '\0'; //覆盖第一个多余的数字
    }
    str.swap(string(str.c_str())); //删除NULL之后多余的字符
    return str;
}

posted on 2017-07-07 12:31  yutingliuyl  阅读(14519)  评论(0编辑  收藏  举报