c 串转string_c++ 中 char 与 string 之间的相互转换问题
string::c_str()、string::data()的區別:
const value_type *c_str( ) const;
const value_type *data( ) const;
data只是返回原始數據序列,沒有保證會用traits::eos(),或者說'\0'來作字符串結束. ??當然,可能多數實現都這樣做了。
c_str是標準的做法,返回的char*???一定指向一個合法的用'\0'終止的C兼容的字符串。
所以,如果需要C兼容的字符串,c_str ?是標準的做法,data ?并不保證所有STL的實現的一致性。
你或許會問,c_str()的功能包含data(),那還需要data()函數干什么?看看源碼:
const charT* c_str () const
{
if??(length () == 0)
return "";
terminate ();
return data ();
}
原來c_str()的流程是:先調用terminate(),然后在返回data()。因此如果你對效率要求比較高,而且你的處理又不一定需要以\0的方式結束,你最好選擇data()。但是對于一般的C函數中,需要以const char*為輸入參數,你就要使用c_str()函數。
對于c_str() data()函數,返回的數組都是由string本身擁有,千萬不可修改其內容。其原因是許多string實現的時候采用了引用機制,也就是說,有可能幾個string使用同一個字符存儲空間。而且你不能使用sizeof(string)來查看其大小。詳細的解釋和實現查看Effective STL的條款15:小心string實現的多樣性。
另外在你的程序中,只在需要時才使用c_str()或者data()得到字符串,每調用一次,下次再使用就會失效,如:
string strinfo("this is Winter");
...
//最好的方式是:
foo(strinfo.c_str());
//也可以這么用:
const char* pstr=strinfo.c_str();
foo(pstr);
//不要再使用了pstr了, 下面的操作已經使pstr無效了。
strinfo += " Hello!";
foo(pstr);//錯誤!
會遇到什么錯誤?當你幸運的時候pstr可能只是指向"this is Winter Hello!"的字符串,如果不幸運,就會導致程序出現其他問題,總會有一些不可遇見的錯誤??傊粫悄泐A期的那個結果。
strcpy
C語言標準庫函數strcpy,把從src地址開始且含有'\0'結束符的字符串復制到 ?以dest開始的地址空間。
總結
以上是生活随笔為你收集整理的c 串转string_c++ 中 char 与 string 之间的相互转换问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 黄金一钱等于多少克
- 下一篇: 对没有标记为安全的activex控件进行