operator-(std::reverse_iterator)
Von cppreference.com
< cpp | iterator | reverse iterator
| Definiert in Header <iterator> |
||
| template< class Iter1, class Iter2 > typename reverse_iterator<Iter>::difference_type |
(bis C++11) | |
template< class Iter1, class Iter2 > auto operator-( const reverse_iterator<Iter1>& lhs, |
(seit C++11) (constexpr seit C++17) |
|
Gibt die Distanz zwischen zwei Iterator-Adaptern zurück.
Inhalt |
[bearbeiten] Parameter
| lhs, rhs | - | Iterator-Adaptoren, für die die Differenz berechnet werden soll |
[bearbeiten] Rückgabewert
rhs.base() - lhs.base()
[bearbeiten] Hinweise
operator- gibt rhs.base() - lhs.base() anstelle von lhs.base() - rhs.base() zurück, da dies ein umgekehrter Iterator ist.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <iostream> #include <iterator> #include <list> #include <vector> int main() { std::vector vec{0, 1, 2, 3}; std::reverse_iterator<std::vector<int>::iterator> vec_ri1{std::reverse_iterator{vec.rbegin()}}, vec_ri2{std::reverse_iterator{vec.rend()}}; std::cout << (vec_ri2 - vec_ri1) << ' '; // 4 std::cout << (vec_ri1 - vec_ri2) << '\n'; // -4 std::list lst{5, 6, 7, 8}; std::reverse_iterator<std::list<int>::iterator> lst_ri1{std::reverse_iterator{lst.rbegin()}}, lst_ri2{std::reverse_iterator{lst.rend()}}; // auto n = (lst_ri1 - lst_ri2); // Error: the underlying iterators do not // model random access iterator }
Ausgabe
4 -4
[bearbeiten] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 280 | C++98 | heterogene Subtraktion war nicht erlaubt | erlaubt |
[bearbeiten] Siehe auch
bewegt den reverse_iterator vorwärts oder rückwärts(öffentliche Memberfunktion) | |
| bewegt den Iterator vorwärts (Funktionstemplate) |