Sdílet prostřednictvím


basic_string::data

Převede obsah řetězce na pole znaků.

const value_type *data( ) const;

Vrácená hodnota

Ukazatel na první prvek pole obsahující obsah řetězce nebo prázdné pole, ukazatel hodnotu null, který nelze přímo odkázat.

Poznámky

Objekty typu řetězec patřící k basic_string třída šablony jazyka C++ <char> jsou nutně null ukončena.Návratový typ pro dat není platný řetězec C, protože získá připojen žádný znak null.Prázdný znak '\0' se používá jako speciální znak v řetězci C konec řetězce, ale nemá žádný zvláštní význam v objektu typu String a může být součástí objektu string stejně jako jakýkoli jiný znak.

Je automatický převod z const char * do řetězce, ale řetězec třídy neposkytuje pro automatické převody z řetězce C-styl na objekty typu basic_string <char>.

Vrácený řetězec není vhodné měnit, protože to by mohlo znehodnotit ukazatel na řetězec nebo odstranit, protože řetězec, který má omezenou životnost a je vlastněna řetězec třídy.

Příklad

// basic_string_data.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;
}
  

Požadavky

Hlavička: <string>

Obor názvů: std

Viz také

Referenční dokumentace

basic_string – třída