std::string转char可用c_str()获取只读指针,或手动分配内存实现可修改字符串;2. char转std::string通过构造函数自动深拷贝;3. 注意空指针检查、内存泄漏、编码一致性和临时对象生命周期问题。

在C++开发中,char*(C风格字符串)和std::string是两种常见的字符串表示方式。虽然std::string更安全、更方便,但在调用C语言接口或处理底层数据时,经常需要与char*进行转换。下面介绍几种常用的相互转换方法。
string 转 char*
将std::string转换为char*时,需要注意返回的指针是否可修改,以及生命周期管理。
- 使用
c_str()获取只读的C风格字符串指针:
std::string str = "Hello";
const char* cstr = str.c_str();
// cstr 可用于传参,但不能修改内容
- 如果需要可修改的
char*,可以手动分配内存并复制:
std::string str = "Hello";
char* writable = new char[str.size() + 1];
strcpy(writable, str.c_str());
// 使用完记得释放:
// delete[] writable;
注意:c_str()返回的指针在原string对象被修改或析构后会失效,不要长期保存。
char* 转 string
将C风格字符串转为std::string非常简单,构造函数会自动处理。
立即学习“C++免费学习笔记(深入)”;
- 从
const char*创建string:
const char* cstr = "Hello";
std::string str(cstr);
- 如果
char*指向的是非空结尾字符串,可指定长度:
char data[] = {'H', 'i', '!', 'X'};
std::string str(data, 3); // 只取前3个字符
这种转换是深拷贝,新string拥有独立内存,原char*释放不影响它。
常见注意事项
实际使用中容易忽略以下几点:
-
空指针检查:转换前确保
char*不为nullptr,否则std::string构造会崩溃。 -
内存泄漏:手动分配的
char*必须配对delete[]。 - 编码问题:多字节或UTF-8字符串需确保两端处理一致。
-
临时对象陷阱:如
func(string("abc").c_str())可能导致未定义行为,因临时对象在表达式结束后析构。
基本上就这些。掌握char*和string之间的转换,能更好兼容C/C++混合编程场景,同时避免常见错误。关键是理解生命周期和所有权,写起来就不容易出错。










