Namespaces
Variants

std::ranges::adjacent_view<V,N>:: iterator

From cppreference.net
Ranges library
Range adaptors
template < bool Const >
class /*iterator*/
(начиная с C++23)
( только для демонстрации* )

Тип возвращаемого значения adjacent_view::begin , а также adjacent_view::end , когда базовое представление V является common_range .

Тип /*iterator*/ < true > возвращается константными перегруженными версиями. Тип /*iterator*/ < false > возвращается неконстантными перегруженными версиями.

Содержание

Типы членов

Тип члена Определение
Base (private) const V если Const равно true , иначе V .
( только для демонстрации* )
iterator_category std:: input_iterator_tag
iterator_concept
value_type std:: tuple < /*REPEAT*/ ( ranges:: range_value_t < Base > , N ) ... > ;
difference_type ranges:: range_difference_t < Base >

Члены данных

Объект-член Определение
current_ (private) std:: array < ranges:: iterator_t < Base > , N > .
( объект-член только для демонстрации* )

Функции-члены

создает итератор
(public member function)
обращается к элементу
(public member function)
обращается к элементу по индексу
(public member function)
перемещает или уменьшает базовые итераторы
(public member function)

Функции, не являющиеся членами класса

сравнивает базовые итераторы
(функция)
выполняет арифметические операции с итераторами
(функция)
(C++23)
преобразует результат разыменования базового итератора в соответствующий тип rvalue-ссылки
(функция)
(C++23)
обменивает объекты, на которые указывают два базовых итератора
(функция)

Пример

#include <cassert>
#include <concepts>
#include <list>
#include <ranges>
#include <tuple>
#include <utility>
#include <vector>
int main()
{
    auto v = std::vector{0, 1, 2, 3, 4, 5};
    auto i = (v | std::views::adjacent<3>).begin();
    using I = decltype(i);
    static_assert(std::same_as<I::value_type, std::tuple<int, int, int>>);
    static_assert(std::same_as<I::iterator_concept, std::random_access_iterator_tag>);
    // некоторые из доступных операторов:
    ++i; i++; --i; i--; i += 2; i -= 2;
    assert(i[2] == std::tuple(2, 3, 4));
    using DI = decltype(*i);
    static_assert(std::same_as<DI, std::tuple<int&, int&, int&>>);
    std::get<1>(*i) = 42; // изменяет v[1] через итератор i
    assert(v[1] == 42);
    auto l = std::list{0, 1, 2, 3, 4, 5};
    auto j = (l | std::views::adjacent<3>).begin();
    using J = decltype(j);
    static_assert(std::same_as<J::value_type, std::tuple<int, int, int>>);
    static_assert(std::same_as<J::iterator_concept, std::bidirectional_iterator_tag>);
    ++j; --j; j++; j--; // некоторые из доступных операторов
    // j += 2; j -= 2;       // ошибка: эти операторы недоступны
    // std::ignore() = j[1]; //        для двунаправленного итератора
}

Ссылки

  • Стандарт C++23 (ISO/IEC 14882:2024):
  • 26.7.25.3 Шаблон класса adjacent_view::iterator [range.adjacent.iterator]

Смотрите также