Namespaces
Variants

std::ranges::adjacent_view<V,N>:: iterator <Const>:: operator++,--,+=,-=

From cppreference.net
Ranges library
Range adaptors
constexpr /*iterator*/ & operator ++ ( ) ;
(1) (C++23부터)
constexpr /*iterator*/ operator ++ ( int ) ;
(2) (C++23부터)
constexpr /*iterator*/ & operator -- ( )
requires ranges:: bidirectional_range < Base > ;
(3) (C++23부터)
constexpr /*iterator*/ operator -- ( int )
requires ranges:: bidirectional_range < Base > ;
(4) (C++23부터)
constexpr /*iterator*/ & operator + = ( difference_type n )
requires ranges:: random_access_range < Base > ;
(5) (C++23부터)
constexpr /*iterator*/ & operator - = ( difference_type n )
requires ranges:: random_access_range < Base > ;
(6) (C++23부터)

반복자를 증가시키거나 감소시킵니다.

current_ 를 기반 반복자 배열이라고 하자.

1) 다음 코드와 동일함:
for (auto& i : current_)
    i = std::ranges::next(i);
return *this;
호출 전에 current_. back ( ) 가 증가 가능하지 않을 경우 동작은 정의되지 않음.
2) 다음과 동일함:
auto tmp = *this;
++*this;
return tmp;
3) 다음에 해당함:
for (auto& i : current_)
    i = std::ranges::prev(i);
return *this;
호출 전에 current_. front ( ) 가 감소 가능하지 않으면 동작은 정의되지 않음.
4) 다음과 동일함:
auto tmp = *this;
--*this;
return tmp;
5) 동등한 코드:
for (auto& i : current_)
    i = i + n;
return *this;
호출 전에 current_. back ( ) + n 이 잘 정의된 동작을 가지지 않는 경우, 동작은 정의되지 않습니다.
6) 동등한 코드:
for (auto& i : current_)
    i = i - n;
return *this;
호출 전에 current_. front ( ) - n 이 잘 정의된 동작을 가지지 않는 경우, 동작은 정의되지 않습니다.

목차

매개변수

n - 현재 위치 기준 상대적 위치

반환값

1,3,5,6) * this
2,4) 변경 전에 생성된 * this 의 복사본.

예제

#include <cassert>
#include <list>
#include <ranges>
#include <utility>
#include <vector>
int main()
{
    {
        auto v = std::vector{0, 1, 2, 3, 4, 5};
        auto i = (v | std::views::pairwise).begin();
        assert((*i == std::pair{0, 1}));
        ++i;                            // 오버로드 (1)
        assert((*i == std::pair{1, 2}));
        --i;                            // 오버로드 (3)
        assert((*i == std::pair{0, 1}));
        i += 2;                         // 오버로드 (5)
        assert((*i == std::pair{2, 3}));
        i -= 2;                         // 오버로드 (6)
        assert((*i == std::pair{0, 1}));
    }
    {
        auto v = std::list{0, 1, 2, 3, 4, 5};
        auto i = (v | std::views::pairwise).begin();
        assert((*i == std::pair{0, 1}));
        ++i;                            // 오버로드 (1)
        assert((*i == std::pair{1, 2}));
        --i;                            // 오버로드 (3)
        assert((*i == std::pair{0, 1}));
//      i += 2; // 오류: v는 random_access_range가 아님; 오버로드 (5)
//      i -= 2; // 오류: v는 random_access_range가 아님; 오버로드 (6)
    }
}

참고 항목

반복자 연산 수행
(public member function)