| Iterator concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator primitives | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Algorithm concepts and utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Indirect callable concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Common algorithm requirements | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator adaptors | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
| Non-member functions | ||||
operator- | ||||
(C++20) | ||||
(C++20) | ||||
(C++14) |
Defined in header <iterator> | ||
template<class Iter1,class Iter2> typename reverse_iterator<Iter>::difference_type | (until C++11) | |
template<class Iter1,class Iter2> auto operator-(const reverse_iterator<Iter1>& lhs, | (since C++11) (constexpr since C++17) | |
Returns the distance between two iterator adaptors.
Contents |
| lhs, rhs | - | iterator adaptors to compute the difference of |
rhs.base()- lhs.base()
operator- returnsrhs.base()- lhs.base() rather thanlhs.base()- rhs.base() because this is a reverse iterator.
#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)<<' ';// 4std::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}
Output:
4 -4
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 280 | C++98 | heterogeneous subtraction was not allowed | allowed |
advances or decrements thereverse_iterator(public member function)[edit] | |
| advances the iterator (function template)[edit] |