標准庫的string類提供了3個成員函數來從一個string得到c類型的字符數組:c_str()、data()、cpy(p,n)。
1. c_str():生成一個const char*指針,指向以空字符終止的數組。
注:
①這個數組的數據是臨時的,當有一個改變這些數據的成員函數被調用後,其中的數據就會失效。因此要麼現用先轉換,要麼把它的數據復制到用戶自己可以管理的內存中。注意。看下例:
const char* c;
string s="1234";
c = s.c_str();
cout<<c<<endl; //輸出:1234
s="abcd";
cout<<c<<endl; //輸出:abcd
上面如果繼續用c指針的話,導致的錯誤將是不可想象的。就如:1234變為abcd
其實上面的c = s.c_str(); 不是一個好習慣。既然c指針指向的內容容易失效,我們就應該按照上面的方法,那怎麼把數據復制出來呢?這就要用到strcpy等函數(推薦)。
//const char* c; //①
//char* c; //②
//char c[20];
char* c=new char;
string s="1234";
//c = s.c_str();
strcpy(c,s.c_str());
cout<<c<<endl; //輸出:1234
s="abcd";
cout<<c<<endl; //輸出:1234
注意:不能再像上面一樣①所示了,const還怎麼向裡面寫入值啊;也不能②所示,使用了未初始化的局部變量“c”,運行會出錯的 。
② c_str()返回一個客戶程序可讀不可改的指向字符數組的指針,不需要手動釋放或刪除這個指針。
2. data():與c_str()類似,但是返回的數組不以空字符終止。
3. cpy(p,n,size_type _Off = 0):從string類型對象中至多復制n個字符到字符指針p指向的空間中。默認從首字符開始,但是也可以指定,開始的位置(記住從0開始)。返回真正從對象中復制的字符。------用戶要確保p指向的空間足夠保存n個字符。
// basic_string_copy.cpp
// compile with: /EHsc /W3
#include <string>
#include <iostream>
int main( )
{
using namespace std;
string str1 ( "1234567890" );
basic_string <char>::iterator str_Iter;
char array1 [ 20 ] = { 0 };
char array2 [ 10 ] = { 0 };
basic_string <char>:: pointer array1Ptr = array1;
basic_string <char>:: value_type *array2Ptr = array2;
cout << "The original string str1 is: ";
for ( str_Iter = str1.begin( ); str_Iter != str1.end( ); str_Iter++ )
cout << *str_Iter;
cout << endl;
basic_string <char>:: size_type nArray1;
// Note: string::copy is potentially unsafe, consider
// using string::_Copy_s instead.
nArray1 = str1.copy ( array1Ptr , 12 ); // C4996
cout << "The number of copied characters in array1 is: "
<< nArray1 << endl;
cout << "The copied characters array1 is: " << array1Ptr << endl;
basic_string <char>:: size_type nArray2;
// Note: string::copy is potentially unsafe, consider
// using string::_Copy_s instead.
nArray2 = str1.copy ( array2Ptr , 5 , 6 ); // C4996
cout << "The number of copied characters in array2 is: "
<< nArray2 << endl;
cout << "The copied characters array2 is: " << array2Ptr << endl;
////注意一定要使array3有足夠的空間
//char array3[5]={0};
//basic_string<char>::pointer array3Ptr=array3;
//basic_string<char>::size_type nArray3;
//nArray3 = str1.copy(array3,9); //錯誤!!!!
//cout<<"The number of copied characters in array3 is: "
// <<nArray3<<endl;
//cout<<"The copied characters array3 is: "<<array3Ptr<<endl;
}
上面最後注釋掉的部分,雖然編譯沒有錯誤,但是運行時會產生錯誤:Stack around the variable 'array3' was corrupted.
摘自 csqlwy