Namespaces
Variants

std:: input_or_output_iterator

From cppreference.net
Iterator library
Iterator concepts
input_or_output_iterator
(C++20)

Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
Definido en el encabezado <iterator>
template < class I >

concepto input_or_output_iterator =
requiere ( I i ) {
{ * i } - > /*can-reference*/ ;
} &&

std:: weakly_incrementable < I > ;
(desde C++20)

El concepto input_or_output_iterator constituye la base de la taxonomía de conceptos de iteradores; cada tipo de iterador satisface los requisitos de input_or_output_iterator .

El concepto de solo exposición /*can-reference*/ se satisface si y solo si el tipo es referenceable .

Notas

input_or_output_iterator solo especifica operaciones para desreferenciar e incrementar un iterador. La mayoría de los algoritmos requerirán operaciones adicionales, por ejemplo:

A diferencia de los LegacyIterator requirements, el concepto input_or_output_iterator no requiere capacidad de copia.

* i debe ser de preservación de igualdad, aunque las operaciones de incremento requeridas por weakly_incrementable no lo son.

Ejemplo

Un iterador mínimo.

#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>);