c_str()函数用于string与const char之间的转换;
string.c_str是Borland封装的String类中的一个函数,它返回当前字符串的首字符地址;
c_str函数的返回值是const char的,不能直接赋值给char*,所以就需要我们进行相应的操作转化。
//标准库的string类提供了三个成员函数来从一个string得到c类型的字符数组
//主要介绍c_str
//c_str():生成一个const char*指针,指向以空字符终止的数组。(data()与c_str()类似,但是返回的数组不以空字符终止。)
//这个数组应该是string类内部的数组
#include <iostream>
//需要包含cstring的字符串
#include <cstring>
using namespace std;
int main()
{
//string-->char*
//c_str()函数返回一个指向正规C字符串的指针, 内容是字符串对象的当前内容加上一个额外的终止字符(‘\ 0’)。
//这个数组的数据是临时的,当有一个改变这些数据的成员函数被调用后,其中的数据就会失效。
//因此要么现用先转换,要么把它的数据复制到用户自己可以管理的内存中
// c_str()返回一个客户程序可读不可改的指向字符数组的指针,不需要手动释放或删除这个指针。
string s = "1234";
c = s.c_str();
cout<<c<<endl; //1234,如果为*c,则输出结果为1
s = "abcde";
cout<<c<<endl; //abcde
}
注意:一定要使用strcpy()等函数来操作c_str()返回的指针。例如下面这样写是错误的:
char *c;
string s="1234";
c=s.c_str();
上述代码中,c最后指向的内容是垃圾,因为s对象被析构,其内容被处理,同时编译器会报错,正确代码如下:
char *cstr,*p;
string str("Please split this phrase into tokens");
cstr=new char[str.size() +1];//str.size()仅仅是字符的长度
strcpy(cstr,str.c_str());
陷阱:
#include <iostream>
#include <string>
int main() {
std::string s = "Chelse";
const char *str = s.c_str();
std::cout << str << std::endl; //输出 Chelse
s[1] = 'm';
std::cout << str << std::endl; //输出 Cmhelse
return 0;
}
const char*的值应该是个常量啊,怎么还能改变值呢?
答:str这个const char的生命周期及string类的实现有关,string的c_str()返回的指针是由string管理的,因此它的生命期是string对象的生命期,而string类的实现实际上封装着一个char的指针,而c_str()直接返回该指针的引用,因此string对象的改变会直接影响已经执行过的c_str()返回的指针引用。简而言之,调用任何 std::string 的非 const 成员函数以后,c_str() 的返回值就不可靠了。