我想要做的是這樣的:如何轉字符串爲char *(不爲const char *)
string result;
char* a[100];
a[0]=result;
似乎result.c_str()必須爲const char *。有沒有辦法做到這一點?
我想要做的是這樣的:如何轉字符串爲char *(不爲const char *)
string result;
char* a[100];
a[0]=result;
似乎result.c_str()必須爲const char *。有沒有辦法做到這一點?
你可以這樣做:
char a[100];
::strncpy(a, result.c_str(), 100);
小心空終止。
您可以獲取字符串中第一個字符的地址。
a[0] = &result[0];
這是保證在C++ 11中工作。 (內部字符串表示必須是連續的,並且像C風格字符串那樣以空字符結尾)
在C++ 03中,這些保證不存在,但所有常見實現都可以使用。
我不認爲它會編譯,除非a被聲明爲const(或者除非拋棄const_ness) – 2013-04-25 04:50:58
@JeremyFriesner它不是const。 http://en.cppreference.com/w/cpp/string/basic_string/operator_at – 2013-04-25 04:59:56
Phooey,對吧。我收回我的評論:) – 2013-04-25 14:34:00
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];
的老式方法:
#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!
如果你願意lly,真的不能避免這樣做,你不應該拋棄C++提供的所有東西,並且降低使用原始數組和可怕的函數,如strncpy
。
一種合理的可能性是將數據從字符串複製到一個向量:
char const *temp = result.c_str();
std::vector<char> a(temp, temp+result.size()+1);
您通常可以忽略字符串的數據,但 - 如果你需要一個非const字符串指針的數據,你可以使用&result[0]
。
轉移到'const char *',然後做一個'strcpy' – pickypg 2013-04-24 04:34:30
是的,它的工作!非常感謝! – user1933667 2013-04-24 04:41:30
這可能是XY問題。你能告訴我們你要做什麼嗎?在大多數情況下,你應該問如何避免這樣做,而不是問怎麼做。 – 2013-04-24 04:41:44