<ol><li>const char 可直接构造 std::String,但指针需有效;2. std::string 用 c_str() 转 const char,生命周期受限于原字符串;3. char 转 std::string 会复制内容,反之需手动分配内存复制;4. const char 不可直接转 char*,应复制避免修改只读内存。</li></ol>

在C++中,char*、const char* 和 std::string 是处理字符串的常见类型。它们各有用途,但在实际开发中经常需要相互转换。下面介绍几种常用且安全的转换方法。
1. const char* 转 std::string
这是最简单的一种转换,std::string 构造函数支持直接从 const char* 初始化。
示例:
const char* cstr = "Hello World"; std::string str(cstr); // 或 std::string str = cstr;
如果 cstr 为 NULLptr,行为是未定义的,使用前需确保指针有效。
立即学习“C++免费学习笔记(深入)”;
2. std::string 转 const char*
使用 c_str() 成员函数可获取指向以 null 结尾的 C 风格字符串的指针。
std::string str = "Hello World"; const char* cstr = str.c_str(); // 返回 const char*
注意:返回的指针仅在原 string 对象生命周期内有效,且不能修改其内容(因为是 const)。
3. char* 与 std::string 的互转
char* 是非 const 指针,通常用于可修改的字符串缓冲区。
char* 转 std::string:
char* data = new char[12]; strcpy(data, "Hello World"); std::string str(data); // 自动复制内容 delete[] data; // 转换后仍需管理原始内存
string 会复制数据,原 char* 可安全释放。
std::string 转 char*:
不能直接转,因为 c_str() 返回的是 const char*。如需可写副本,必须手动复制。
std::string str = "Hello World"; char* writable = new char[str.size() + 1]; strcpy(writable, str.c_str()); // 复制内容到可写内存 // 使用 writable... delete[] writable; // 记得释放
也可用 strncpy 防止溢出,更安全。
4. const char* 与 char* 的转换
const char* 到 char*:不能直接转,除非使用 const_cast,但非常危险。
const char* src = "Hello"; char* dst = const_cast<char*>(src); // 不推荐!字符串字面量不可修改 // strcpy(dst, "New"); // 运行时错误!
正确做法是复制一份可写副本,如上节所示。
char* 到 const char*:可以直接赋值,因为权限只读化是安全的。
char* writable = ...; const char* readable = writable; // 合法
基本上就这些。掌握这些转换方式,能避免很多内存错误和编译问题。关键是理解所有权和可变性,别试图修改只读内存。转换时优先使用 std::string 管理生命周期,减少裸指针使用。不复杂但容易忽略细节。


