.TH "std::reverse_iterator< _Iterator >" 3cxx "Fri Dec 19 2014" "libstdc++" \" -*- nroff -*- .ad l .nh .SH NAME std::reverse_iterator< _Iterator > \- .SH SYNOPSIS .br .PP .PP Inherits \fBstd::iterator< iterator_traits< _Iterator >::iterator_category, iterator_traits< _Iterator >::value_type, iterator_traits< _Iterator >::difference_type, iterator_traits< _Iterator >::pointer, iterator_traits< _Iterator >::reference >\fP\&. .SS "Public Types" .in +1c .ti -1c .RI "typedef .br __traits_type::difference_type \fBdifference_type\fP" .br .ti -1c .RI "typedef iterator_traits .br < _Iterator > .br ::\fBiterator_category\fP \fBiterator_category\fP" .br .ti -1c .RI "typedef _Iterator \fBiterator_type\fP" .br .ti -1c .RI "typedef __traits_type::pointer \fBpointer\fP" .br .ti -1c .RI "typedef __traits_type::reference \fBreference\fP" .br .ti -1c .RI "typedef iterator_traits .br < _Iterator >::\fBvalue_type\fP \fBvalue_type\fP" .br .in -1c .SS "Public Member Functions" .in +1c .ti -1c .RI "\fBreverse_iterator\fP ()" .br .ti -1c .RI "\fBreverse_iterator\fP (iterator_type __x)" .br .ti -1c .RI "\fBreverse_iterator\fP (const \fBreverse_iterator\fP &__x)" .br .ti -1c .RI "template \fBreverse_iterator\fP (const \fBreverse_iterator\fP< _Iter > &__x)" .br .ti -1c .RI "iterator_type \fBbase\fP () const " .br .ti -1c .RI "reference \fBoperator*\fP () const " .br .ti -1c .RI "\fBreverse_iterator\fP \fBoperator+\fP (difference_type __n) const " .br .ti -1c .RI "\fBreverse_iterator\fP & \fBoperator++\fP ()" .br .ti -1c .RI "\fBreverse_iterator\fP \fBoperator++\fP (int)" .br .ti -1c .RI "\fBreverse_iterator\fP & \fBoperator+=\fP (difference_type __n)" .br .ti -1c .RI "\fBreverse_iterator\fP \fBoperator-\fP (difference_type __n) const " .br .ti -1c .RI "\fBreverse_iterator\fP & \fBoperator--\fP ()" .br .ti -1c .RI "\fBreverse_iterator\fP \fBoperator--\fP (int)" .br .ti -1c .RI "\fBreverse_iterator\fP & \fBoperator-=\fP (difference_type __n)" .br .ti -1c .RI "pointer \fBoperator->\fP () const " .br .ti -1c .RI "reference \fBoperator[]\fP (difference_type __n) const " .br .in -1c .SS "Protected Types" .in +1c .ti -1c .RI "typedef iterator_traits .br < _Iterator > \fB__traits_type\fP" .br .in -1c .SS "Protected Attributes" .in +1c .ti -1c .RI "_Iterator \fBcurrent\fP" .br .in -1c .SH "Detailed Description" .PP .SS "templateclass std::reverse_iterator< _Iterator >" Bidirectional and random access iterators have corresponding reverse iterator adaptors that iterate through the data structure in the opposite direction\&. They have the same signatures as the corresponding iterators\&. The fundamental relation between a reverse iterator and its corresponding iterator \fCi\fP is established by the identity: .PP .nf &*(reverse_iterator(i)) == &*(i - 1) .fi .PP .PP \fIThis 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\&.\fP [24\&.4\&.1]/1,2 .PP 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\&. .PP Definition at line 96 of file stl_iterator\&.h\&. .SH "Member Typedef Documentation" .PP .SS "typedef iterator_traits< _Iterator >::\fBiterator_category\fP \fBstd::iterator\fP< iterator_traits< _Iterator >::\fBiterator_category\fP , iterator_traits< _Iterator >::\fBvalue_type\fP , iterator_traits< _Iterator >::difference_type , iterator_traits< _Iterator >::pointer , iterator_traits< _Iterator >::reference >::\fBiterator_category\fP\fC [inherited]\fP" .PP One of the \fBtag types\fP\&. .PP Definition at line 121 of file stl_iterator_base_types\&.h\&. .SS "typedef iterator_traits< _Iterator >::\fBvalue_type\fP \fBstd::iterator\fP< iterator_traits< _Iterator >::\fBiterator_category\fP , iterator_traits< _Iterator >::\fBvalue_type\fP , iterator_traits< _Iterator >::difference_type , iterator_traits< _Iterator >::pointer , iterator_traits< _Iterator >::reference >::\fBvalue_type\fP\fC [inherited]\fP" .PP The type 'pointed to' by the iterator\&. .PP Definition at line 123 of file stl_iterator_base_types\&.h\&. .SH "Constructor & Destructor Documentation" .PP .SS "template \fBstd::reverse_iterator\fP< _Iterator >::\fBreverse_iterator\fP ()\fC [inline]\fP" The default constructor value-initializes member \fCcurrent\fP\&. If it is a pointer, that means it is zero-initialized\&. .PP Definition at line 120 of file stl_iterator\&.h\&. .PP Referenced by std::reverse_iterator< _Iterator >::operator+(), and std::reverse_iterator< _Iterator >::operator-()\&. .SS "template \fBstd::reverse_iterator\fP< _Iterator >::\fBreverse_iterator\fP (iterator_type__x)\fC [inline]\fP, \fC [explicit]\fP" This iterator will move in the opposite direction that \fCx\fP does\&. .PP Definition at line 126 of file stl_iterator\&.h\&. .SS "template \fBstd::reverse_iterator\fP< _Iterator >::\fBreverse_iterator\fP (const \fBreverse_iterator\fP< _Iterator > &__x)\fC [inline]\fP" The copy constructor is normal\&. .PP Definition at line 131 of file stl_iterator\&.h\&. .SS "template template \fBstd::reverse_iterator\fP< _Iterator >::\fBreverse_iterator\fP (const \fBreverse_iterator\fP< _Iter > &__x)\fC [inline]\fP" A reverse_iterator across other types can be copied if the underlying iterator can be converted to the type of \fCcurrent\fP\&. .PP Definition at line 139 of file stl_iterator\&.h\&. .SH "Member Function Documentation" .PP .SS "template iterator_type \fBstd::reverse_iterator\fP< _Iterator >::base () const\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 \fCcurrent\fP, the iterator used for underlying work\&. .RE .PP .PP Definition at line 146 of file stl_iterator\&.h\&. .PP Referenced by std::operator==()\&. .SS "template reference \fBstd::reverse_iterator\fP< _Iterator >::operator* () const\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 A reference to the value at \fC--current\fP .RE .PP This requires that \fC--current\fP is dereferenceable\&. .PP \fBWarning:\fP .RS 4 This implementation requires that for an iterator of the underlying iterator type, \fCx\fP, a reference obtained by \fC*x\fP remains valid after \fCx\fP has been modified or destroyed\&. This is a bug: http://gcc.gnu.org/PR51823 .RE .PP .PP Definition at line 160 of file stl_iterator\&.h\&. .PP Referenced by std::reverse_iterator< _Iterator >::operator->()\&. .SS "template \fBreverse_iterator\fP \fBstd::reverse_iterator\fP< _Iterator >::operator+ (difference_type__n) const\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 A reverse_iterator that refers to \fCcurrent\fP - \fI__n\fP .RE .PP The underlying iterator must be a Random Access Iterator\&. .PP Definition at line 231 of file stl_iterator\&.h\&. .PP References std::reverse_iterator< _Iterator >::reverse_iterator()\&. .SS "template \fBreverse_iterator\fP& \fBstd::reverse_iterator\fP< _Iterator >::operator++ ()\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 \fC*this\fP .RE .PP Decrements the underlying iterator\&. .PP Definition at line 181 of file stl_iterator\&.h\&. .SS "template \fBreverse_iterator\fP \fBstd::reverse_iterator\fP< _Iterator >::operator++ (int)\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 The original value of \fC*this\fP .RE .PP Decrements the underlying iterator\&. .PP Definition at line 193 of file stl_iterator\&.h\&. .SS "template \fBreverse_iterator\fP& \fBstd::reverse_iterator\fP< _Iterator >::operator+= (difference_type__n)\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 *this .RE .PP Moves the underlying iterator backwards \fI__n\fP steps\&. The underlying iterator must be a Random Access Iterator\&. .PP Definition at line 241 of file stl_iterator\&.h\&. .SS "template \fBreverse_iterator\fP \fBstd::reverse_iterator\fP< _Iterator >::operator- (difference_type__n) const\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 A reverse_iterator that refers to \fCcurrent\fP - \fI__n\fP .RE .PP The underlying iterator must be a Random Access Iterator\&. .PP Definition at line 253 of file stl_iterator\&.h\&. .PP References std::reverse_iterator< _Iterator >::reverse_iterator()\&. .SS "template \fBreverse_iterator\fP& \fBstd::reverse_iterator\fP< _Iterator >::operator-- ()\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 \fC*this\fP .RE .PP Increments the underlying iterator\&. .PP Definition at line 206 of file stl_iterator\&.h\&. .SS "template \fBreverse_iterator\fP \fBstd::reverse_iterator\fP< _Iterator >::operator-- (int)\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 A reverse_iterator with the previous value of \fC*this\fP .RE .PP Increments the underlying iterator\&. .PP Definition at line 218 of file stl_iterator\&.h\&. .SS "template \fBreverse_iterator\fP& \fBstd::reverse_iterator\fP< _Iterator >::operator-= (difference_type__n)\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 *this .RE .PP Moves the underlying iterator forwards \fI__n\fP steps\&. The underlying iterator must be a Random Access Iterator\&. .PP Definition at line 263 of file stl_iterator\&.h\&. .SS "template pointer \fBstd::reverse_iterator\fP< _Iterator >::operator-> () const\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 A pointer to the value at \fC--current\fP .RE .PP This requires that \fC--current\fP is dereferenceable\&. .PP Definition at line 172 of file stl_iterator\&.h\&. .PP References std::reverse_iterator< _Iterator >::operator*()\&. .SS "template reference \fBstd::reverse_iterator\fP< _Iterator >::operator[] (difference_type__n) const\fC [inline]\fP" .PP \fBReturns:\fP .RS 4 The value at \fCcurrent\fP - \fI__n\fP - 1 .RE .PP The underlying iterator must be a Random Access Iterator\&. .PP Definition at line 275 of file stl_iterator\&.h\&. .SH "Author" .PP Generated automatically by Doxygen for libstdc++ from the source code\&.