basic_string::c_str
Converte il contenuto di una stringa come c stile, stringa con terminazione null.
const value_type *c_str( ) const;
Valore restituito
Un puntatore alla versione di tipo C stringa di chiamata. Il valore del puntatore non valido dopo una chiamata a una funzione non const, incluso il distruttore, nella classe basic_string sull'oggetto.
Note
Oggetti di tipo supporti l'appartenenza alla classe modello di C++ basic_stringchar<> non sono necessariamente con terminazione null. "\ 0 " Del carattere null viene utilizzato come carattere speciale in c dalla stringa per contrassegnare la fine della stringa ma non ha un significato speciale in un oggetto di tipo string e può essere una parte della stringa come qualsiasi altro carattere. Esiste una conversione automatica da const Carattere a destra esteso le stringhe, ma la classe string non offre le conversioni automatiche da stringhe di tipo C agli oggetti di tipo basic_string<char>.
La stringa di tipo C restituita non deve essere modificata, poiché potrebbe invalidare il puntatore alla stringa, o eliminati, poiché la stringa ha una durata limitata ed è posseduta dalla stringa della classe.
Esempio
// basic_string_c_str.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
string str1 ( "Hello world" );
cout << "The original string object str1 is: "
<< str1 << endl;
cout << "The length of the string object str1 = "
<< str1.length ( ) << endl << endl;
// Converting a string to an array of characters
const char *ptr1 = 0;
ptr1= str1.data ( );
cout << "The modified string object ptr1 is: " << ptr1
<< endl;
cout << "The length of character array str1 = "
<< strlen ( ptr1) << endl << endl;
// Converting a string to a C-style string
const char *c_str1 = str1.c_str ( );
cout << "The C-style string c_str1 is: " << c_str1
<< endl;
cout << "The length of C-style string str1 = "
<< strlen ( c_str1) << endl << endl;
}
Requisiti
Intestazione: <string>
Spazio dei nomi: std