std:: input_or_output_iterator
| Iterator concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator primitives | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Algorithm concepts and utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Indirect callable concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Common algorithm requirements | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator adaptors | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Definiert im Header
<iterator>
|
||
|
template
<
class
I
>
concept input_or_output_iterator
=
|
(seit C++20) | |
Das
input_or_output_iterator
Konzept bildet die Grundlage der Iterator-Konzept-Taxonomie; jeder Iterator-Typ erfüllt die
input_or_output_iterator
Anforderungen.
Das exposition-only-Konzept /*can-reference*/ ist genau dann erfüllt, wenn der Typ referenzierbar ist.
Hinweise
input_or_output_iterator
selbst spezifiziert nur Operationen zum Dereferenzieren und Inkrementieren eines Iterators. Die meisten Algorithmen werden zusätzliche Operationen benötigen, zum Beispiel:
-
Vergleichen von Iteratoren mit Sentinels (siehe
sentinel_for); -
Lesen von Werten aus einem Iterator (siehe
indirectly_readableundinput_iterator); -
Schreiben von Werten in einen Iterator (siehe
indirectly_writableundoutput_iterator); -
Eine erweiterte Menge von Iterator-Bewegungen (siehe
forward_iterator,bidirectional_iterator,random_access_iterator).
Im Gegensatz zu den
LegacyIterator
-Anforderungen erfordert das Konzept
input_or_output_iterator
keine Kopierbarkeit.
*
i
muss gleichheitserhaltend sein, obwohl die Inkrementoperationen, die von
weakly_incrementable
gefordert werden, dies nicht sind.
Beispiel
Ein minimaler Iterator.
#include <cstddef> #include <iterator> struct SimpleIterator { using difference_type = std::ptrdiff_t; int operator*(); SimpleIterator& operator++(); void operator++(int) { ++*this; } }; static_assert(std::input_or_output_iterator<SimpleIterator>);