std::ranges::adjacent_view<V,N>:: iterator <Const>:: operator++,--,+=,-=
From cppreference.net
<
cpp
|
ranges
|
adjacent view
|
iterator
C++
Ranges library
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
std::ranges::adjacent_view
| Member functions | ||||
|
(C++26)
|
||||
| Iterator | ||||
| Member functions | ||||
|
adjacent_view::
iterator
::operator++
adjacent_view:: iterator ::operator++ (int) adjacent_view:: iterator ::operator-- adjacent_view:: iterator ::operator-- (int) adjacent_view:: iterator ::operator+= adjacent_view:: iterator ::operator-= |
||||
| Non-member functions | ||||
| Sentinel | ||||
| Member functions | ||||
| Non-member functions | ||||
|
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)
다음 코드와 동일함:
호출 전에
current_.
back
(
)
가 증가 가능하지 않을 경우 동작은 정의되지 않음.
for (auto& i : current_) i = std::ranges::next(i); return *this;
2)
다음과 동일함:
auto tmp = *this; ++*this; return tmp;
3)
다음에 해당함:
호출 전에
current_.
front
(
)
가 감소 가능하지 않으면 동작은 정의되지 않음.
for (auto& i : current_) i = std::ranges::prev(i); return *this;
4)
다음과 동일함:
auto tmp = *this; --*this; return tmp;
5)
동등한 코드:
호출 전에
current_.
back
(
)
+
n
이 잘 정의된 동작을 가지지 않는 경우, 동작은 정의되지 않습니다.
for (auto& i : current_) i = i + n; return *this;
6)
동등한 코드:
호출 전에
current_.
front
(
)
-
n
이 잘 정의된 동작을 가지지 않는 경우, 동작은 정의되지 않습니다.
for (auto& i : current_) i = i - n; return *this;
목차 |
매개변수
| 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) } }
참고 항목
|
(C++23)
|
반복자 연산 수행
(public member function) |