c++怎样把double转为string
2016-04-30 · 知道合伙人互联网行家
关注
展开全部
方法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<sstream> 老类是<strstream> ,即用strstream类来代替stringstream
stringstream ss;
ss<<34.45;
string t;
t<<ss
ss.clear()
方法3:
函数名: gcvt 功 能: 把浮点数转换成字符串 用 法: char *gcvt(double value, int ndigit, char *buf); 头文件:#include <stdlib.h> 参数: value——被转换的值。 Digits——存储的有效数字位数。 Buffe——结果的存储位置。 说明: gcvt函数把一个浮点值转换成一个字符串(包括一个小数点和可能的 符号字节)并存储该字符串在buffer中。该buffer应足够大以便容纳转换 的值加上结尾的空格字符,它是自动添加的。如果一个缓冲区的尺寸为 digits的尺寸+1,该函数覆盖该缓冲区的末尾。这是因为转换的字符串包 括一个小数点以及可能包含符号和指数信息。不提供上溢出。gcvt试图 以十进制格式产生digits数字,如果不可能,它以指数格式产生digits数字, 在转换时可能截除尾部的0。
是用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<sstream> 老类是<strstream> ,即用strstream类来代替stringstream
stringstream ss;
ss<<34.45;
string t;
t<<ss
ss.clear()
方法3:
函数名: gcvt 功 能: 把浮点数转换成字符串 用 法: char *gcvt(double value, int ndigit, char *buf); 头文件:#include <stdlib.h> 参数: value——被转换的值。 Digits——存储的有效数字位数。 Buffe——结果的存储位置。 说明: gcvt函数把一个浮点值转换成一个字符串(包括一个小数点和可能的 符号字节)并存储该字符串在buffer中。该buffer应足够大以便容纳转换 的值加上结尾的空格字符,它是自动添加的。如果一个缓冲区的尺寸为 digits的尺寸+1,该函数覆盖该缓冲区的末尾。这是因为转换的字符串包 括一个小数点以及可能包含符号和指数信息。不提供上溢出。gcvt试图 以十进制格式产生digits数字,如果不可能,它以指数格式产生digits数字, 在转换时可能截除尾部的0。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
方法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<sstream> 老类是<strstream> ,即用strstream类来代替stringstream
stringstream ss;
ss<<34.45;
string t;
t<<ss
ss.clear()
方法3:
函数名: gcvt 功 能: 把浮点数转换成字符串 用 法: char *gcvt(double value, int ndigit, char *buf); 头文件:#include <stdlib.h> 参数: value——被转换的值。 Digits——存储的有效数字位数。 Buffe——结果的存储位置。 说明: gcvt函数把一个浮点值转换成一个字符串(包括一个小数点和可能的 符号字节)并存储该字符串在buffer中。该buffer应足够大以便容纳转换 的值加上结尾的空格字符,它是自动添加的。如果一个缓冲区的尺寸为 digits的尺寸+1,该函数覆盖该缓冲区的末尾。这是因为转换的字符串包 括一个小数点以及可能包含符号和指数信息。不提供上溢出。gcvt试图 以十进制格式产生digits数字,如果不可能,它以指数格式产生digits数字, 在转换时可能截除尾部的0。
是用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<sstream> 老类是<strstream> ,即用strstream类来代替stringstream
stringstream ss;
ss<<34.45;
string t;
t<<ss
ss.clear()
方法3:
函数名: gcvt 功 能: 把浮点数转换成字符串 用 法: char *gcvt(double value, int ndigit, char *buf); 头文件:#include <stdlib.h> 参数: value——被转换的值。 Digits——存储的有效数字位数。 Buffe——结果的存储位置。 说明: gcvt函数把一个浮点值转换成一个字符串(包括一个小数点和可能的 符号字节)并存储该字符串在buffer中。该buffer应足够大以便容纳转换 的值加上结尾的空格字符,它是自动添加的。如果一个缓冲区的尺寸为 digits的尺寸+1,该函数覆盖该缓冲区的末尾。这是因为转换的字符串包 括一个小数点以及可能包含符号和指数信息。不提供上溢出。gcvt试图 以十进制格式产生digits数字,如果不可能,它以指数格式产生digits数字, 在转换时可能截除尾部的0。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2018-08-01 · 百度知道合伙人官方认证企业
育知同创教育
1【专注:Python+人工智能|Java大数据|HTML5培训】 2【免费提供名师直播课堂、公开课及视频教程】 3【地址:北京市昌平区三旗百汇物美大卖场2层,微信公众号:yuzhitc】
向TA提问
关注
展开全部
ftoa:浮点数强制成字符串,
这个不是C标准库中的函数,而是Windows平台下扩展的,标准库中有sprintf,功能比这个更强,用法跟printf类似:
char str[255];
sprintf(str, "%f", 10.8); //将10.8转为字符串
c++中有itoa,没有ftoa,要使用自己编写。
一般用:
CString str;
str.Format("%f", 1.2345);
AfxMessageBox(str);
这个不是C标准库中的函数,而是Windows平台下扩展的,标准库中有sprintf,功能比这个更强,用法跟printf类似:
char str[255];
sprintf(str, "%f", 10.8); //将10.8转为字符串
c++中有itoa,没有ftoa,要使用自己编写。
一般用:
CString str;
str.Format("%f", 1.2345);
AfxMessageBox(str);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询