#include <iostream>
#include <string>
#include <cstdlib>
#include <sstream>
#include <cstring>
using namespace std;
//第一种C风格的转化(以前一直喜欢的 sprintf 功能强大)
void test()
{
char *s = "dong";
int a = 52;
float b = .1314;
char *buf = new char[strlen(s) + sizeof(a) + 1];
sprintf(buf, "%s%d%.4f", s, a, b);
printf("%sn", buf);
}
//半C半C++风格
void test1()
{
string s = "dong";
int a = 520;
char *buf = new char[10];//2147483647 int最大值
_itoa(a, buf, 10); //itoa虽然可以转化为各种进制,但是注意不能是float或者double
cout << s + buf << " | ";
_itoa(a, buf, 16);
cout << s + buf << endl;
}
//纯C++风格
void test2()
{
string s = "陈明东";
int a = 52;
double b = .1314;
ostringstream oss;
oss << s << a << b;
cout << oss.str() << endl;
}
//C++11新特性
void test3()
{
int a = 520;
float b = 5.20;
string str = "dong";
string res = str + to_string(a);
cout << res << endl;
res = str + to_string(b);
res.resize(8);
cout << res << endl;
}
int main()
{
test();
test1();
test2();
test3();
return 0;
}
/*
dong520.1314
dong520 | dong208
陈明东520.1314
dong520
dong5.20
*/
多次使用stringstream,要先清空下stream.clear();
由于stringstream构造函数会特别消耗内存,似乎不打算主动释放内存(或许是为了提高效率),但如果你要在程序中用同一个流,反复读写大量的数据,将会造成大量的内存消耗,因些这时候,需要适时地清除一下缓冲 (用 stream.str("") )。
另外不要企图用 stream.str().resize(0),或 stream.str().clear() 来清除缓冲,使用它们似乎可以让stringstream的内存消耗不要增长得那么快,但仍然不能达到清除stringstream缓冲的效果,内存的消耗还在缓慢的增长!
最后,还是推荐使用c++ 11的to_string()方法,简单方便。
参考:
C++中4种方式把字符串和数字连接起来 - 帅东's Blog - CSDN博客