Namespaces
Variants

std::experimental::ranges:: Iterator

From cppreference.net
template < class I >

concept bool Iterator =
requires ( I i ) {
{ * i } - > auto && ; // Voraussetzung: i ist dereferenzierbar
} &&

WeaklyIncrementable < I > ;
(ranges TS)

Das Iterator -Konzept bildet die Grundlage der Iterator-Konzept-Taxonomie; jeder Iterator erfüllt die Iterator -Anforderungen.

Gleichheitserhaltung

Ein Ausdruck ist equality preserving , wenn er bei gleichen Eingaben gleiche Ausgaben liefert.

  • Die Eingaben eines Ausdrucks bestehen aus seinen Operanden.
  • Die Ausgaben eines Ausdrucks bestehen aus seinem Ergebnis und allen durch den Ausdruck modifizierten Operanden (falls vorhanden).

Jeder Ausdruck, der gleichungserhaltend sein muss, muss darüber hinaus stabil sein: Zwei Auswertungen eines solchen Ausdrucks mit denselben Eingabeobjekten müssen gleiche Ausgaben liefern, sofern keine explizite Änderung dieser Eingabeobjekte zwischen den Auswertungen erfolgt.

Sofern nicht anders angegeben, muss jeder Ausdruck, der in einem requires-expression verwendet wird, gleichheitserhaltend und stabil sein, und die Auswertung des Ausdrucks darf nur seine nicht-konstanten Operanden modifizieren. Operanden, die konstant sind, dürfen nicht modifiziert werden.

Hinweise

Iterator selbst spezifiziert nur Operationen zum Dereferenzieren und Inkrementieren eines Iterators. Die meisten Algorithmen werden zusätzliche Operationen benötigen, zum Beispiel:

Die - > auto && -Einschränkung impliziert, dass der Ergebnistyp der Dereferenzierung nicht void sein kann.