最简单安全的方式是用 std::string 构造函数传入 char* 指针:默认构造得空字符串;非空指针需确保以 '\0' 结尾或显式指定长度;nullptr 会抛异常;构造时立即拷贝,不依赖原指针生命周期。

直接用 std::string 的构造函数即可,最简单安全的方式就是传入 char* 指针。
基础用法:默认构造(空字符串)
如果只是想创建一个空的 std::string,不需要转换:
char* cstr = nullptr; std::string s; // 空字符串,不依赖 cstr
标准转换:用 char* 构造 string
只要 char* 指向以 '\0' 结尾的有效 C 字符串,就能直接构造:
char cstr[] = "Hello"; std::string s(cstr); // ✅ 推荐写法 // 或简写为: std::string s2 = cstr; // ✅ 同样有效,隐式调用构造函数
- 构造时会自动计算长度(直到遇到
'\0') - 内部完成内存分配和内容拷贝,原
char*可后续释放或复用 - 若
cstr为nullptr,会抛出std::logic_error(C++11 起)
带长度的转换:避免依赖 '\0' 终止符
当你的 当你的 char* 不保证以 ' 结尾(比如来自二进制数据、子串截取),用带长度的构造函数更安全:char* 不保证以 '\0' 结尾(比如来自二进制数据、子串截取),用带长度的构造函数更安全:
立即学习“C++免费学习笔记(深入)”;
char data[] = {'H', 'e', 'l', 'l', 'o'};
std::string s(data, 5); // ✅ 明确指定长度,不查 '\0'
- 第二个参数是字符个数,不是字节数(对 ASCII/UTF-8 单字节字符等价)
- 即使
data中间有'\0',也会按指定长度完整拷贝 - 若长度为 0,得到空字符串;长度超界行为未定义,需确保合法
注意事项与常见错误
别忘了指针有效性与生命周期:
// ❌ 危险:指向栈上临时数组,函数返回后失效
std::string bad_example() {
char local[] = "temp";
return std::string(local); // 构造时已拷贝,没问题 ✅
// 但下面这句才真正危险:
// char* p = local; return std::string(p); // 同样 ✅ —— 因为 string 立即拷贝了内容
}
// ✅ 安全关键:确保 char* 在构造 string 时有效(哪怕只是一瞬间)
// ❌ 错误示例(运行时崩溃):
char* p = nullptr;
std::string s(p); // 抛异常:basic_string::_S_construct null not valid
-
std::string构造时会立即复制内容,不持有原始指针 - 不必担心原
char*后续被释放(只要构造时还有效) - 始终检查是否为
nullptr,尤其从 C API 获取的指针
基本上就这些。核心就一条:用 std::string s(ptr) 或 std::string s(ptr, len),其余交给标准库处理。










