Namensräume
Varianten
Aktionen

std::basic_string<CharT,Traits,Allocator>::data

Von cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
 
const CharT* data() const;
(1) (noexcept seit C++11)
(constexpr seit C++20)
CharT* data() noexcept;
(2) (seit C++17)
(constexpr seit C++20)

Gibt einen Zeiger auf das zugrundeliegende Array zurück, das als Zeichenspeicher dient. Der Zeiger ist so beschaffen, dass der Bereich

[data()data() + size())

(bis C++11)

[data()data() + size()]

(seit C++11)

gültig ist und die darin enthaltenen Werte den im String gespeicherten Werten entsprechen.

Das zurückgegebene Array muss nicht nullterminiert sein.

Wenn empty() true zurückgibt, ist der Zeiger ein nicht-null Zeiger, der nicht dereferenziert werden sollte.

(bis C++11)

Das zurückgegebene Array ist nullterminiert, d. h. data() und c_str() führen dieselbe Funktion aus.

Wenn empty() true zurückgibt, zeigt der Zeiger auf ein einzelnes Nullzeichen.

(seit C++11)

Der von data() erhaltene Zeiger kann ungültig werden durch

1) Das Modifizieren des Zeichenarrays, auf das über die const-Überladung von data zugegriffen wird, hat undefiniertes Verhalten zur Folge.
2) Das Modifizieren des Nullterminators nach dem Ende, der bei data() + size() gespeichert ist, auf einen anderen Wert als CharT() hat undefiniertes Verhalten zur Folge.

Inhalt

[edit] Parameter

(keine)

[edit] Rückgabewert

Ein Zeiger auf den zugrundeliegenden Zeichenspeicher.

data()[i] == operator[](i) für jedes i in [0size)).

(bis C++11)

data() + i == std::addressof(operator[](i)) für jedes i in [0size)].

(seit C++11)

[edit] Komplexität

Konstant.

[edit] Beispiel

#include <algorithm>
#include <cassert>
#include <cstring>
#include <string>
 
int main()
{
    std::string const s("Emplary");
    assert(s.size() == std::strlen(s.data()));
    assert(std::equal(s.begin(), s.end(), s.data()));
    assert(std::equal(s.data(), s.data() + s.size(), s.begin()));
    assert('\0' == *(s.data() + s.size()));
}

[edit] Siehe auch

(DR*)
greift auf das erste Zeichen zu
(public member function) [edit]
(DR*)
greift auf das letzte Zeichen zu
(public member function) [edit]
gibt eine nicht modifizierbare Standard-C-Zeichen-Array-Version des Strings zurück
(public member function) [edit]
gibt einen Zeiger auf das erste Zeichen einer Ansicht zurück
(public member function of std::basic_string_view<CharT,Traits>) [edit]