std::ranges::adjacent_view<V,N>::Iterator<Const>::operator++,--,+=,-=
Von cppreference.com
< cpp | ranges | adjacent view | iterator
| constexpr /*iterator*/& operator++(); |
(1) | (seit C++23) |
| constexpr /*Iterator*/ operator++( int ); |
(2) | (seit C++23) |
| constexpr /*Iterator*/& operator--() requires ranges::bidirectional_range<Base>; |
(3) | (seit C++23) |
| constexpr /*Iterator*/ operator--( int ) requires ranges::bidirectional_range<Base>; |
(4) | (seit C++23) |
| constexpr /*Iterator*/& operator+=( difference_type n ) requires ranges::random_access_range<Base>; |
(5) | (seit C++23) |
| constexpr /*Iterator*/& operator-=( difference_type n ) requires ranges::random_access_range<Base>; |
(6) | (seit C++23) |
Inkrementiert oder dekrementiert den Iterator.
Sei current_ ein zugrunde liegendes Array von Iteratoren.
1) Äquivalent zuDas Verhalten ist undefiniert, wenn vor dem Aufruf current_.back() nicht inkrementierbar ist.
for (auto& i : current_) i = std::ranges::next(i); return *this;
2) Äquivalent zu
auto tmp = *this; ++*this; return tmp;
3) Äquivalent zuDas Verhalten ist undefiniert, wenn vor dem Aufruf current_.front() nicht dekrementierbar ist.
for (auto& i : current_) i = std::ranges::prev(i); return *this;
4) Äquivalent zu
auto tmp = *this; --*this; return tmp;
5) Äquivalent zuDas Verhalten ist undefiniert, wenn vor dem Aufruf current_.back() + n kein wohldefiniertes Verhalten aufweist.
for (auto& i : current_) i = i + n; return *this;
6) Äquivalent zuDas Verhalten ist undefiniert, wenn vor dem Aufruf current_.front() - n kein wohldefiniertes Verhalten aufweist.
for (auto& i : current_) i = i - n; return *this;
Inhalt |
[bearbeiten] Parameter
| n | - | Position relativ zur aktuellen Position |
[bearbeiten] Rückgabewert
1,3,5,6) *this
2,4) Eine Kopie von *this, die vor der Änderung erstellt wurde.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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; // overload (1) assert((*i == std::pair{1, 2})); --i; // overload (3) assert((*i == std::pair{0, 1})); i += 2; // overload (5) assert((*i == std::pair{2, 3})); i -= 2; // overload (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; // overload (1) assert((*i == std::pair{1, 2})); --i; // overload (3) assert((*i == std::pair{0, 1})); // i += 2; // Error: v is not a random_access_range; overload (5) // i -= 2; // Error: v is not a random_access_range; overload (6) } }
[bearbeiten] Siehe auch
| (C++23) |
führt Iterator-Arithmetik durch (öffentliche Memberfunktion) |