1. 程式人生 > >string 與char* char[]區別及轉化

string 與char* char[]區別及轉化

一、定義

string:string可以被看成是以字元為元素的一種容器。字元構成序列(字串)。有時候在字元序列中進行遍歷,標準的string類提供了STL容器介面。具有一些成員函式比如begin()、end(),迭代器可以根據他們進行定位。與char*不同的是,string不一定以NULL('\0')結束。string長度可以根據length()得到,string可以根據下標訪問。所以,不能將string直接賦值給char*。

char*: char *是一個指標,可以指向一個字串陣列,至於這個陣列可以在棧上分配,也可以在堆上分配,堆得話就要你手動釋放了。

二、區別主要
string的記憶體管理是由系統處理,除非系統記憶體池用完,不然不會出現這種記憶體問題。
char *的記憶體管理由使用者自己處理,很容易出現記憶體不足的問題。

當我們要存一個串,但是不知道其他需要多少記憶體時, 用string來處理就最好不過了。
當你知道了儲存的記憶體的時候,可以用char *,但是不如用string的好,用指標總會有
隱患。

用string還可以使用各種成員函式來處理串的每一個字元,方便處理。
用char *處理串,就不如string的方便了,沒有相應的函式來直接呼叫,而是要自己編
寫函式來完成串的處理,而且處理過程中用指標還很容易出現記憶體問題。

char *s="string"的內容是不可以改的;char s[10]="string"的內容是可以改的

三、相互轉化

1、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<<k<<t<<endl;

如上,都可以輸出。內容是一樣的。但是隻能轉換成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<<data;

2、char *轉換成string

可以直接賦值。

string s;

char *p = "adghrtyh";

s = p;

不過這個是會出現問題的。

有一種情況我要說明一下。當我們定義了一個string型別之後,用printf("%s",s1);輸出是會出問題的。這是因為“%s”要求後面的物件的首地址。但是string不是這樣的一個型別。所以肯定出錯。

用cout輸出是沒有問題的,若一定要printf輸出。那麼可以這樣:

printf("%s",s1.c_str())

3、char[] 轉換成string
這個也可以直接賦值。但是也會出現上面的問題。需要同樣的處理。

4、string轉換成char[]
這個由於我們知道string的長度,可以根據length()函式得到,又可以根據下標直接訪問,所以用一個迴圈就可以賦值了。

這樣的轉換不可直接賦值。

string pp = "dagah";

char p[8];
int i;

for( i=0;i<pp.length();i++)
p[i] = pp[i];

p[i] = '\0';
printf("%s\n",p);

cout<<p;