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

在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(src); // 不推荐!字符串字面量不可修改// strcpy(dst, "New"); // 运行时错误!
正确做法是复制一份可写副本,如上节所示。
char* 到 const char*:可以直接赋值,因为权限只读化是安全的。
char* writable = ...;const char* readable = writable; // 合法
基本上就这些。掌握这些转换方式,能避免很多内存错误和编译问题。关键是理解所有权和可变性,别试图修改只读内存。转换时优先使用 std::string 管理生命周期,减少裸指针使用。不复杂但容易忽略细节。
以上就是c++++中char*, const char*, 和std::string之间的转换 _c++字符指针与string互转方法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1480978.html
微信扫一扫
支付宝扫一扫