Namespaces
Variants

std::reverse_iterator<Iter>:: operator*,->

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
reference operator * ( ) const ;
(1) (constexpr начиная с C++17)
(2)
pointer operator - > ( ) const ;
(constexpr начиная с C++17)
(до C++20)
constexpr pointer operator - > ( ) const

requires ( std:: is_pointer_v < Iter > ||

requires ( const Iter i ) { i. operator - > ( ) ; } ) ;
(начиная с C++20)

Возвращает ссылку или указатель на элемент, предшествующий current .

Функция-член Эквивалентно
operator * Iter tmp = current ; return *-- tmp ;
operator - >

return & ( operator * ( ) ) ;

(до C++11)

return std:: addressof ( operator * ( ) ) ;

(начиная с C++11)
(до C++20)
  • return current - 1 ; если Iter является типом указателя
  • return std:: prev ( current ) . operator - > ( ) ; в противном случае
(начиная с C++20)

Содержание

Возвращаемое значение

Как описано выше.

Пример

#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";
}

Вывод:

*r0 = 3
a[3] = 42
*r1 = 1
vc[2] = (5,6)

Отчеты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Применяется к Поведение в опубликованной версии Корректное поведение
LWG 2188 C++11 operator - > использовал & для взятия адреса использует std::addressof вместо этого

Смотрите также

обращается к элементу по индексу
(публичная функция-член)