如何将字符串传递给char *(不是const char *)

时间:2013-04-24 04:32:55

标签: c++

我想做类似的事情:

string result;
char* a[100];
a[0]=result;

似乎result.c_str()必须是const char *。有没有办法做到这一点?

6 个答案:

答案 0 :(得分:5)

您可以获取字符串中第一个字符的地址。

a[0] = &result[0];

这保证可以在C ++ 11中使用。 (内部字符串表示必须是连续的,并且像C样式的字符串一样以null结尾)

在C ++ 03中,这些保证不存在,但所有常见的实现都可以。

答案 1 :(得分:1)

string result;
char a[100] = {0};
strncpy(a, result.c_str(), sizeof(a) - 1);

答案 2 :(得分: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];

答案 3 :(得分:0)

你可以这样做:

char a[100];
::strncpy(a, result.c_str(), 100);

小心空终止。

答案 4 :(得分:0)

老式的方式:

#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!

答案 5 :(得分:0)

如果你真的,真的不能避免这样做,你不应该抛弃C ++提供的所有东西,而是使用原始数组和可怕的函数,如strncpy

一种合理的可能性是将数据从字符串复制到向量:

char const *temp = result.c_str();
std::vector<char> a(temp, temp+result.size()+1);

您通常可以将数据保留在字符串中 - 如果您需要指向字符串数据的非常量指针,则可以使用&result[0]