轉載:http://www.cnblogs.com/qlwy/archive/2012/03/25/2416937.html
標準庫的string類提供了3個成員函數來從一個string得到c類型的字符數組:c_str()、data()、copy(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 [20]; 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. copy(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.