我想做类似的事情:
string result;
char* a[100];
a[0]=result;
似乎 result.c_str() 必须是 const char*。有没有办法做到这一点?
我想做类似的事情:
string result;
char* a[100];
a[0]=result;
似乎 result.c_str() 必须是 const char*。有没有办法做到这一点?
您可以获取字符串中第一个字符的地址。
a[0] = &result[0];
这保证在 C++11 中工作。(内部字符串表示必须是连续的,并且像 C 风格的字符串一样以空值结尾)
在 C++03 中这些保证不存在,但所有常见的实现都可以工作。
string result;
char a[100] = {0};
strncpy(a, result.c_str(), sizeof(a) - 1);
有一个名为“copy”的成员函数(方法)来完成这项工作。
但您需要先创建缓冲区。
像这样
string result;
char* a[100];
a[0] = new char[result.length() + 1];
result.copy(a[0], result.length(), 0);
a[0][result.length()] = '\0';
(参考:http ://www.cplusplus.com/reference/string/basic_string/copy/ )
顺便说一句,我想知道你的意思是
string result;
char a[100];
你可以做:
char a[100];
::strncpy(a, result.c_str(), 100);
小心空终止。
老套路:
#include <string.h>
a[0] = strdup(result.c_str()); // allocates memory for a new string and copies it over
[...]
free(a[0]); // don't forget this or you leak memory!
如果你真的、真的无法避免这样做,你不应该抛弃 C++ 提供的所有东西,转而使用原始数组和可怕的函数,例如strncpy
.
一种合理的可能性是将数据从字符串复制到向量:
char const *temp = result.c_str();
std::vector<char> a(temp, temp+result.size()+1);
不过,您通常可以将数据保留在字符串中——如果您需要指向字符串数据的非常量指针,则可以使用&result[0]
.