Namensräume
Varianten
Aktionen

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

Von cppreference.com
< cpp‎ | ranges‎ | adjacent view‎ | iterator
 
 
Bereichsbibliothek
Range-Adaptoren
 
 
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 zu
for (auto& i : current_)
    i = std::ranges::next(i);
return *this;
Das Verhalten ist undefiniert, wenn vor dem Aufruf current_.back() nicht inkrementierbar ist.
2) Äquivalent zu
auto tmp = *this;
++*this;
return tmp;
3) Äquivalent zu
for (auto& i : current_)
    i = std::ranges::prev(i);
return *this;
Das Verhalten ist undefiniert, wenn vor dem Aufruf current_.front() nicht dekrementierbar ist.
4) Äquivalent zu
auto tmp = *this;
--*this;
return tmp;
5) Äquivalent zu
for (auto& i : current_)
    i = i + n;
return *this;
Das Verhalten ist undefiniert, wenn vor dem Aufruf current_.back() + n kein wohldefiniertes Verhalten aufweist.
6) Äquivalent zu
for (auto& i : current_)
    i = i - n;
return *this;
Das Verhalten ist undefiniert, wenn vor dem Aufruf current_.front() - n kein wohldefiniertes Verhalten aufweist.

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

#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

führt Iterator-Arithmetik durch
(öffentliche Memberfunktion)