char * strc = new char[strlen(str.c_str())+1]; strcpy(strc, str.c_str())
這樣轉是返回一個串 而不是指針,如果直接
char *p = const_cast<char*>(a.c_str());
則返回的不正確。
string path = path_buff; path = path + "\\sky.jpg"; int charlength = strlen(path.c_str()) + 1; char* strc = new char[charlength]; strcpy_s(strc, charlength, path.c_str()); return strc;
1、如果要將string轉換為char*,可以使用string提供的函數c_str() ,或是函數data(),data除了返回字符串內容外,不附加結束符'\0',而c_str()返回一個以‘\0’結尾的字符數組。
2、const char *c_str();
c_str()函數返回一個指向正規C字符串的指針,內容與本string串相同.
這是為了與c語言兼容,在c語言中沒有string類型,故必須通過string類對象的成員函數c_str()把string 對象轉換成c中的字符串樣式.
注意:一定要使用strcpy()函數 等來操作方法c_str()返回的指針
比如:最好不要這樣:
char* c;
string s="1234";
c = s.c_str(); //c最后指向的內容是垃圾,因為s對象被析構,其內容被處理
應該這樣用:
char c[20];
string s="1234";
strcpy(c,s.c_str());
這樣才不會出錯,c_str()返回的是一個臨時指針,不能對其進行操作
再舉個例子
c_str() 以 char* 形式傳回 string 內含字符串
如果一個函數要求char*參數,可以使用c_str()方法:
string s = "Hello World!";
printf("%s",s.c_str()); //輸出 "Hello World!"
1、
const char *p = a.data();
2、
const char *p = a.c_str();
3、
char *p = const_cast<char*>(a.c_str());
頭段時間有人問過我這個問題,可是我一點頭緒都沒有,直接說不會。現在從網上找了點資料,看了看,知道點東西了。
一、string轉char*。
主要有三種方法可以將str轉換為char*類型,分別是:data(); c_str(); copy();
1.data()方法,如:
1 string str = "hello"; 2 const char* p = str.data();//加const 或者用char * p=(char*)str.data();的形式
同時有一點需要說明,這里在devc++中編譯需要添加const,否則會報錯invalid conversion from const char* to char *,這里可以再前面加上const或者在等號后面給強制轉化成char*的類型。
下面解釋下該問題,const char*是不能直接賦值到char*的,這樣編譯都不能通過,理由:假如可以的話,那么通過char*就可以修改const char指向的內容了,這是不允許的。所以char*要另外開辟新的空間,即上面的形式。
2.c_str()方法,如:
1 string str=“world”; 2 const char *p = str.c_str();//同上,要加const或者等號右邊用char*
3.copy()方法,如:
1 string str="hmmm"; 2 char p[50]; 3 str.copy(p, 5, 0);//這里5代表復制幾個字符,0代表復制的位置, 4 *(p+5)=‘\0’;//注意手動加結束符!!!
二、char * 轉string。
可以直接賦值。
1 string s; 2 char *p = "hello";//直接賦值 3 s = p;
這里有一點要說明,當聲明了string類型變量s后,用printf("%s",s);是會出錯的,因為“%s”要求后面的對象的首地址。但是string不是這樣的一個類型。所以肯定出錯。
三、string轉char[]
這個由於我們知道string的長度,可以根據length()函數得到,又可以根據下標直接訪問,所以用一個循環就可以賦值了。
1 string pp = "dagah"; 2 char p[8]; 3 int i; 4 for( i=0;i<pp.length();i++) 5 p[i] = pp[i]; 6 p[i] = '\0'; 7 printf("%s\n",p); 8 cout<<p;
四、char[]轉string
這里可以直接賦值。
string 與char* char[]之間的轉換_C 語言
1、首先必須了解,string可以被看成是以字符為元素的一種容器。字符構成序列(字符串)。有時候在字符序列中進行遍歷,標准的string類提供了STL容器接口。具有一些成員函數比如begin()、end(),迭代器可以根據他們進行定位。
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<<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;
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
這個也可以直接賦值。但是也會出現上面的問題。需要同樣的處理。
5、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;