如何将字符串转换为char*(不是const char*)

How can I transfer string to char* (not const char*)

本文关键字:char const 不是 字符串 转换      更新时间:2023-10-16

我想这样写:

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()] = '';

(参考文献:http://www.cplusplus.com/reference/string/basic_string/copy/)

顺便说一下,我想知道你是指
string result;
char a[100];

你可以这样做:

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

注意null终止

传统方式:

#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

一种合理的可能性是将数据从string对象复制到vector对象:
char const *temp = result.c_str();
std::vector<char> a(temp, temp+result.size()+1);

你通常可以把数据留在字符串中——如果你需要一个指向字符串数据的非const指针,你可以使用&result[0]