C++ string 轉 char*


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;

 

c++ string轉char*

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;




免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM