Udostępnij za pośrednictwem


basic_string::data

Konwertuje ciąg zawartości tablicy znaków.

const value_type *data( ) const;

Wartość zwracana

Wskaźnik do pierwszego elementu tablicy, zawierające zawartość, ciągu lub pustej tablicy, wskaźnik niezerowe, że nie można usunąć odwołania.

Uwagi

Obiekty typu ciąg należące do klasy szablonów języka C++ w basic_string <char> nie musi koniecznie null są zakończone.Typem zwracanym dla dane nie jest prawidłowym ciągiem C, ponieważ znak null nie pobiera dołączane.Znak null '\0' jest używana jako znak specjalny w ciągu C, aby oznaczyć koniec ciągu, ale nie ma specjalnego znaczenia w obiekcie typu ciąg i może być częścią obiektu ciąg, podobnie jak inne znaki.

Istnieje automatyczna konwersja z const char * do ciągów, ale ciąg klasy nie przewiduje automatycznego konwersji ciągów c styl obiektów typu basic_string <char>.

Zwrócony ciąg nie powinny być modyfikowane, ponieważ to może unieważnić wskaźnik do ciągu lub usunięty, ponieważ ciąg ograniczony okres istnienia i właścicielem jest ciąg klasy.

Przykład

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

Wymagania

Nagłówek: <string>

Obszar nazw: std

Zobacz też

Informacje

basic_string Class