#include <stl_iterator.h>
Inheritance diagram for std::reverse_iterator< _Iterator >:
Public Types | |
typedef iterator_traits< _Iterator >::difference_type | difference_type |
Distance between iterators is represented as this type. | |
typedef iterator_traits< _Iterator >::reference | reference |
This type represents a reference-to-value_type. | |
typedef iterator_traits< _Iterator >::pointer | pointer |
This type represents a pointer-to-value_type. | |
typedef iterator_traits< _Iterator >::iterator_category | iterator_category |
One of the tag types. | |
typedef iterator_traits< _Iterator >::value_type | value_type |
The type "pointed to" by the iterator. | |
Public Member Functions | |
reverse_iterator () | |
reverse_iterator (iterator_type __x) | |
reverse_iterator (const reverse_iterator &__x) | |
template<typename _Iter> | reverse_iterator (const reverse_iterator< _Iter > &__x) |
iterator_type | base () const |
reference | operator * () const |
pointer | operator-> () const |
reverse_iterator & | operator++ () |
reverse_iterator | operator++ (int) |
reverse_iterator & | operator-- () |
reverse_iterator | operator-- (int) |
reverse_iterator | operator+ (difference_type __n) const |
reverse_iterator & | operator+= (difference_type __n) |
reverse_iterator | operator- (difference_type __n) const |
reverse_iterator & | operator-= (difference_type __n) |
reference | operator[] (difference_type __n) const |
i
is established by the identity: &*(reverse_iterator(i)) == &*(i - 1)
This mapping is dictated by the fact that while there is always a pointer past the end of an array, there might not be a valid pointer before the beginning of an array." [24.4.1]/1,2
Reverse iterators can be tricky and surprising at first. Their semantics make sense, however, and the trickiness is a side effect of the requirement that the iterators must be safe.
Definition at line 90 of file stl_iterator.h.
|
Distance between iterators is represented as this type.
Definition at line 103 of file stl_iterator.h. |
|
One of the tag types.
Definition at line 107 of file stl_iterator_base_types.h. |
|
This type represents a pointer-to-value_type.
Definition at line 105 of file stl_iterator.h. |
|
This type represents a reference-to-value_type.
Definition at line 104 of file stl_iterator.h. |
|
The type "pointed to" by the iterator.
Definition at line 109 of file stl_iterator_base_types.h. |
|
The default constructor gives an undefined state to this iterator. Definition at line 111 of file stl_iterator.h. Referenced by std::reverse_iterator< _Iterator >::operator+(), and std::reverse_iterator< _Iterator >::operator-(). |
|
This iterator will move in the opposite direction that Definition at line 117 of file stl_iterator.h. |
|
The copy constructor is normal. Definition at line 122 of file stl_iterator.h. |
|
A reverse_iterator across other types can be copied in the normal fashion. Definition at line 130 of file stl_iterator.h. References std::reverse_iterator< _Iterator >::base(). |
|
Definition at line 137 of file stl_iterator.h. Referenced by std::operator+(), std::operator-(), std::operator==(), and std::reverse_iterator< _Iterator >::reverse_iterator(). |
|
Definition at line 145 of file stl_iterator.h. Referenced by std::reverse_iterator< _Iterator >::operator->(). |
|
Definition at line 214 of file stl_iterator.h. References std::reverse_iterator< _Iterator >::reverse_iterator(). |
|
Definition at line 177 of file stl_iterator.h. |
|
Definition at line 165 of file stl_iterator.h. |
|
Definition at line 223 of file stl_iterator.h. |
|
Definition at line 235 of file stl_iterator.h. References std::reverse_iterator< _Iterator >::reverse_iterator(). |
|
Definition at line 201 of file stl_iterator.h. |
|
Definition at line 190 of file stl_iterator.h. |
|
Definition at line 244 of file stl_iterator.h. |
|
Definition at line 157 of file stl_iterator.h. References std::reverse_iterator< _Iterator >::operator *(). |
|
Definition at line 256 of file stl_iterator.h. |