C++ char*与string相互转换_C++ C风格字符串处理技巧

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非常简单,构造函数会自动处理。

  • 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++混合编程场景,同时避免常见错误。关键是理解生命周期和所有权,写起来就不容易出错。