C++ 中double float转为string的方法

方法1:sprintf(char*destination,char*,double/float)

  是用destination来存储double/float值的字符

然后直接string a(destination)。

该方法有一个缺点,就是存储的值可能和输入的double/float的值有误差,即最后字符串a中的值和输入的double/float的值不一样,如

float f=4.345;

sprintf(destination,"%f",f)

string te=f;

则te的值为4.344971

 

方法2:#include 老类是 ,即用strstream类来代替stringstream

stringstream ss;

ss<<34.45;

string t;

t<

ss.clear()

 

方法3:

函数名: gcvt 功 能: 把浮点数转换成字符串 用 法: char *gcvt(double value, int ndigit, char *buf); 头文件:#include  参数: value——被转换的值。 Digits——存储的有效数字位数。 Buffe——结果的存储位置。 说明: gcvt函数把一个浮点值转换成一个字符串(包括一个小数点和可能的 符号字节)并存储该字符串在buffer中。该buffer应足够大以便容纳转换 的值加上结尾的空格字符,它是自动添加的。如果一个缓冲区的尺寸为 digits的尺寸+1,该函数覆盖该缓冲区的末尾。这是因为转换的字符串包 括一个小数点以及可能包含符号和指数信息。不提供上溢出。gcvt试图 以十进制格式产生digits数字,如果不可能,它以指数格式产生digits数字, 在转换时可能截除尾部的0。

你可能感兴趣的:(C++)