來自:
謝謝原作者!
1、首先必須了解,string可以被看成是以字元為元素的一種容器。字元構成序列(字串)。有時候在字串行中進行遍歷,標準的string類提供了stl容器介面。具有一些成員函式比如begin()、end(),迭代器可以根據他們進行定位。
注意,與char*不同的是,string不一定以null('\0')結束。string長度可以根據length()得到,string可以根據下標訪問。所以,不能將string直接賦值給char*。
2、string 轉換成 char *
如果要將string直接轉換成const char *型別。string有2個函式可以運用。
乙個是.c_str(),乙個是data成員函式。
例子如下:
string s1 = "abcdeg";
const char *k = s1.c_str();
const char *t = s1.data();
printf("%s%s",k,t);
cout<
如上,都可以輸出。內容是一樣的。但是只能轉換成const char*,如果去掉const編譯不能通過。
那麼,如果要轉換成char*,可以用string的乙個成員函式copy實現。
string s1 = "abcdefg";
char *data;
int len = s1.length();
data = (char *)malloc((len+1)*sizeof(char));
s1.copy(data,len,0);
printf("%s",data);
cout<
3、char *轉換成string
可以直接賦值。
string s;
char *p = "adghrtyh";
s = p;
不過這個是會出現問題的。
有一種情況我要說明一下。當我們定義了乙個string型別之後,用printf("%s",s1);輸出是會出問題的。這是因為「%s」要求後面的物件的首位址。但是string不是這樣的乙個型別。所以肯定出錯。
用cout輸出是沒有問題的,若一定要printf輸出。那麼可以這樣:
printf("%s",s1.c_str())
4、char 轉換成string
這個也可以直接賦值。但是也會出現上面的問題。需要同樣的處理。
或這樣char testchar = "0sdfasdfasdfasdf";
std::string teststr;
teststr.assign(testchar);
cclog("**************** >> %s", teststr.data());
cclog("**************** >> %s", teststr.c_str());
都可以輸出:
**************** >> 0sdfasdfasdfasdf
好了!5、string轉換成char
這個由於我們知道string的長度,可以根據length()函式得到,又可以根據下標直接訪問,所以用乙個迴圈就可以賦值了。
這樣的轉換不可直接賦值。
string pp = "dagah";
char p[8];
int i;
for( i=0;i
p[i] = pp[i];
p[i] = '\0';
printf("%s\n",p);
cout<
cclog("**************** >> %s", teststr.data());
string 與char char 之間的轉換
1 首先必須了解,string可以被看成是以字元為元素的一種容器。字元構成序列 字串 有時候在字串行中進行遍歷,標準的string類提供了stl容器介面。具有一些成員函式比如begin end 迭代器可以根據他們進行定位。注意,與char 不同的是,string不一定以null 0 結束。strin...
string 與char char 之間的轉換
1 首先必須了解,string可以被看成是以字元為元素的一種容器。字元構成序列 字串 有時候在字串行中進行遍歷,標準的string類提供了stl容器介面。具有一些成員函式比如begin end 迭代器可以根據他們進行定位。注意,與char 不同的是,string不一定以null 0 結束。strin...
string 與char char 之間的轉換
1 首先必須了解,string可以被看成是以字元為元素的一種容器。字元構成序列 字串 有時候在字串行中進行遍歷,標準的string類提供了stl容器介面。具有一些成員函式比如begin end 迭代器可以根據他們進行定位。注意,與char 不同的是,string不一定以null 0 結束。strin...