使用 stringstream 将整数分配给 char 指针
Assign a integer to char pointer using stringstream
我想使用 stringstream 将整数分配给 char 指针。但是我在 运行 这个程序在 ss >> p 行时出错。请在这里帮助我,我希望整数首先进入缓冲区,并且必须将其分配给 char*。
#include <string> // std::string
#include <iostream> // std::cout
#include <sstream> // std::stringstream
using namespace std;
int main ()
{
stringstream ss;
int n=100;
char *p;
ss << n;
ss >> p; //not working
cout << ss;
return 0;
}
使用stringstream::str获取C++字符串,然后在字符串上使用.c_str():
#include <string> // std::string
#include <iostream> // std::cout
#include <sstream> // std::stringstream
using namespace std;
int main ()
{
stringstream ss;
int n = 100;
char* p;
ss << n;
string tmp = ss.str();
p = const_cast<char*>(tmp.c_str());
cout << "p: " << p << '\n';
return 0;
}
请注意,一旦字符串超出范围,char 指针就会失效。如果您需要某种工厂函数行为,return 按值的字符串,请使用 strlcpy 或者 new 和 shared_ptr.
#include <string> // std::string
#include <iostream> // std::cout
#include <sstream> // std::stringstream
using namespace std;
int main ()
{
stringstream ss;
int n=100;
char buffer[100];
char *p = buffer;
ss << n;
ss >> p;
cout << p;
return 0;
}
这只是解决了您直接遇到的问题 - p
后面没有存储,所以它会崩溃。在文体上还有许多其他需要改进/修复的地方,但这应该会告诉您其中的哪一部分实际上是错误的。
我想使用 stringstream 将整数分配给 char 指针。但是我在 运行 这个程序在 ss >> p 行时出错。请在这里帮助我,我希望整数首先进入缓冲区,并且必须将其分配给 char*。
#include <string> // std::string
#include <iostream> // std::cout
#include <sstream> // std::stringstream
using namespace std;
int main ()
{
stringstream ss;
int n=100;
char *p;
ss << n;
ss >> p; //not working
cout << ss;
return 0;
}
使用stringstream::str获取C++字符串,然后在字符串上使用.c_str():
#include <string> // std::string
#include <iostream> // std::cout
#include <sstream> // std::stringstream
using namespace std;
int main ()
{
stringstream ss;
int n = 100;
char* p;
ss << n;
string tmp = ss.str();
p = const_cast<char*>(tmp.c_str());
cout << "p: " << p << '\n';
return 0;
}
请注意,一旦字符串超出范围,char 指针就会失效。如果您需要某种工厂函数行为,return 按值的字符串,请使用 strlcpy 或者 new 和 shared_ptr.
#include <string> // std::string
#include <iostream> // std::cout
#include <sstream> // std::stringstream
using namespace std;
int main ()
{
stringstream ss;
int n=100;
char buffer[100];
char *p = buffer;
ss << n;
ss >> p;
cout << p;
return 0;
}
这只是解决了您直接遇到的问题 - p
后面没有存储,所以它会崩溃。在文体上还有许多其他需要改进/修复的地方,但这应该会告诉您其中的哪一部分实际上是错误的。