std::ranges::subrange<I,S,K>::next
Von cppreference.com
| constexpr subrange next( std::iter_difference_t<I> n = 1 ) const& requires std::forward_iterator<I>; |
(1) | (seit C++20) |
constexpr subrange next( std::iter_difference_t<I> n = 1 ) &&; |
(2) | (seit C++20) |
Gibt einen subrange zurück, dessen begin_ inkrementiert (oder dekrementiert, wenn n negativ ist) wird. Die tatsächliche Inkrementierung (oder Dekrementierung) wird durch advance() durchgeführt.
1) Gibt eine Kopie von *this zurück.
Äquivalent zu: auto tmp = *this;
tmp.advance(n);
return tmp;.
tmp.advance(n);
return tmp;.
2) Gibt einen von *this verschobenen
subrange zurück. Äquivalent zu: advance(n);
return std::move(*this);.
return std::move(*this);.
Inhalt |
[bearbeiten] Parameter
| n | - | Anzahl der maximalen Inkrementierungen des Iterators |
[bearbeiten] Rückgabewert
Wie oben beschrieben.
[bearbeiten] Hinweise
Der Unterschied zu advance() besteht darin, dass letzteres die Inkrementierung (oder Dekrementierung) direkt vornimmt.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <array> #include <iterator> #include <print> #include <ranges> int main() { std::array arr{1, 2, 3, 4, 5, 6, 7}; std::ranges::subrange sub{std::next(arr.begin(), 2), std::prev(arr.end(), 2)}; std::println("1) sub: {}", sub); std::println("2) sub: {}", sub.next()); std::println("3) sub: {}", sub.next(2)); }
Ausgabe
1) sub: [3, 4, 5] 2) sub: [4, 5] 3) sub: [5]
[bearbeiten] Siehe auch
holt eine Kopie des subrange, bei der der Iterator um einen gegebenen Abstand dekrementiert wurde(public member function) | |
| verschiebt den Iterator um den gegebenen Abstand (public member function) | |
| (C++11) |
inkrementiert einen Iterator (Funktionsvorlage) |
| (C++20) |
inkrementiert einen Iterator um eine gegebene Distanz oder zu einer Grenze (Algorithmus-Funktionsobjekt) |