最简单安全的方式是用 std::string 构造函数传入 char* 指针:默认构造得空字符串;非空指针需确保以 '\0' 结尾或显式指定长度;nullptr 会抛异常;构造时立即拷贝,不依赖原指针生命周期。
直接用 std::string 的构造函数即可,最简单安全的方式就是传入 char* 指针。
如果只是想创建一个空的 std::string,不需要转换:
char* cstr = nullptr; std::string s; // 空字符串,不依赖 cstr
只要 char* 指向以 '\0' 结尾的有效 C 字符串,就能直接构造:
char cstr[] = "Hello"; std::string s(cstr); // ✅ 推荐写法 // 或简写为: std::string s2 = cstr; // ✅ 同样有效,隐式调用构造函数
'\0')char* 可后续释放或
复用cstr 为 nullptr,会抛出 std::logic_error(C++11 起)当你的 当你的 char* 不保证以 ' 结尾(比如来自二进制数据、子串截取),用带长度的构造函数更安全:char* 不保证以 '\0' 结尾(比如来自二进制数据、子串截取),用带长度的构造函数更安全:
立即学习“C++免费学习笔记(深入)”;
char data[] = {'H', 'e', 'l', 'l', 'o'};
std::string s(data, 5); // ✅ 明确指定长度,不查 '\0'
data 中间有 '\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),其余交给标准库处理。