string s("abc");
const char* b = s.c_str();
s.append("def");
cout << b << endl;
输出:abcdef
本来我想直接使用返回的一个与s内容相同的字符串,但是对s追加东西的时候,b所指向的字符串的内容也改变了。所以我们来看看c_str()到底做了什么!
语法:
const char *c_str();
c_str()函数返回一个指向正规C字符串的指针, 内容与本string串相同.
这是为了与c语言兼容,在c语言中没有string类型,故必须通过string类对象的成员函数c_str()把string 对象转换成c中的字符串样式。
那么这个指向正规C字符串的指针到底与string什么关系呢?
它指向了其内部字符数组缓冲区!
并且返回一个const指针,这样我们就不能够根据这个指针来改变string的内容,保护了string的内容,所以说,c_str函数不是平白无故返回了一个const指针。
void makeupper(char* array, int len)
{
for(int i = 0; i < len; ++i)
array[i] = toupper(array[i]);
}
makeupper(&s[0], s.length());
输出:abcdef
由此可见不能直接利用c_str返回的字符串,要利用strcpy等函数进行复制后再使用,不然很危险!