std::reverse_iterator<Iter>:: operator*,->
|
reference operator
*
(
)
const
;
|
(1) | (constexpr desde C++17) |
| (2) | ||
|
pointer operator
-
>
(
)
const
;
|
(constexpr desde C++17)
(hasta C++20) |
|
|
constexpr
pointer operator
-
>
(
)
const
requires
(
std::
is_pointer_v
<
Iter
>
||
|
(desde C++20) | |
Devuelve una referencia o un puntero al elemento anterior a
current
.
| Función miembro | Equivalente a | ||||||
|---|---|---|---|---|---|---|---|
| operator * |
Iter tmp
=
current
;
return
*--
tmp
;
|
||||||
| operator - > |
|
Contenidos |
Valor de retorno
Como se describió anteriormente.
Ejemplo
#include <complex> #include <iostream> #include <iterator> #include <vector> int main() { using RI0 = std::reverse_iterator<int*>; int a[]{0, 1, 2, 3}; RI0 r0{std::rbegin(a)}; std::cout << "*r0 = " << *r0 << '\n'; *r0 = 42; std::cout << "a[3] = " << a[3] << '\n'; using RI1 = std::reverse_iterator<std::vector<int>::iterator>; std::vector<int> vi{0, 1, 2, 3}; RI1 r1{vi.rend() - 2}; std::cout << "*r1 = " << *r1 << '\n'; using RI2 = std::reverse_iterator<std::vector<std::complex<double>>::iterator>; std::vector<std::complex<double>> vc{{1, 2}, {3, 4}, {5, 6}, {7, 8}}; RI2 r2{vc.rbegin() + 1}; std::cout << "vc[2] = (" << r2->real() << ',' << r2->imag() << ")\n"; }
Salida:
*r0 = 3 a[3] = 42 *r1 = 1 vc[2] = (5,6)
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 2188 | C++11 |
operator
-
>
utilizaba
&
para tomar dirección
|
utiliza std::addressof en su lugar |
Véase también
|
accede a un elemento por índice
(función miembro pública) |