浮点型转string
2015-07-15 18:03
176 查看
方法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:
是用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
相关文章推荐
- 自定义ProgressDialog
- PHP面向对象(OOP)编程入门教程链接
- prefix pch 中引用cocoapods 中的头文件失败
- C#注册机与绑定软件(转发自:韩兆新的博客园的C#学习笔记——软件注册与注册机)
- UCI命令系统
- JUnit框架功能详细(Rule、Assume、Assert)——JUnit学习(二)
- 微信朋友圈分享js代码最新2015年无错版
- Storm 配置说明
- 杭电1276士兵队列的训练问题
- mybatis 插入一条数据返回相应数据ID
- groovy语言主要是用来干什么,和JAVA的区别是什么
- 重载->运算符(感觉怪怪的)
- 嵌入式linux之按键驱动程序
- LeetCode Delete Node in a Linked List
- c# 获取客户端ip、mac、机器名、操作系统、浏览器信息
- mnesia
- 【动态口令】基础
- 5分钟开启Esper之旅
- JUnit框架功能详细——JUnit学习(一)
- 浅谈Python Web的五大框架