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

来自cppreference.com
 
 
迭代器库
迭代器概念
迭代器原语
算法概念与工具
间接可调用概念
常用算法要求
(C++20)
(C++20)
(C++20)
工具
(C++20)
迭代器适配器
范围访问
(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) (C++17 起为 constexpr)
(2)
pointer operator->() const;
(C++17 起为 constexpr)
(C++20 前)
constexpr pointer operator->() const
    requires (std::is_pointer_v<Iter> ||
              requires (const Iter i) { i.operator->(); });
(C++20 起)

返回指向 current 前一元素的引用或指针。

1) 等价于 Iter tmp = current; return *--tmp;
2) 等价于:

return &(operator*());

(C++11 前)

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

(C++11 起)
(C++20 前)
  • 如果 Iter 是指针类型,则 return current - 1;
  • 否则 return std::prev(current).operator->();}。
(C++20 起)

返回值

指向 current 之前的元素的引用或指针。

示例

#include <complex>
#include <iostream>
#include <iterator>
#include <list>

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::list<std::complex<double>>::iterator>;
    std::list<std::complex<double>> li{{1, 2}, {3, 4}, {5, 6}};
    const RI1 r1{li.rbegin()};
    std::cout << "*r1 = (" << r1->real() << ',' << r1->imag() << ")\n";
    li.insert(li.end(), std::complex<double>{7, 8});
    std::cout << "*r1 = (" << r1->real() << ',' << r1->imag() << ")\n";
}

输出:

*r0 = 3
a[3] = 42
*r1 = (5,6)
*r1 = (7,8)

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 2188 C++11 operator-> 使用 & 取地址 改用 std::addressof

参阅

按索引访问元素
(公开成员函数) [编辑]