Namespaces
Variants

std::reverse_iterator<Iter>:: reverse_iterator

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)
reverse_iterator ( ) ;
(1) (自 C++17 起为 constexpr)
explicit reverse_iterator ( iterator_type x ) ;
(2) (自 C++17 起为 constexpr)
template < class U >
reverse_iterator ( const reverse_iterator < U > & other ) ;
(3) (自 C++17 起为 constexpr)

构造一个新的 reverse_iterator

重载版本 current
(1) 值初始化
(2) 使用 x 进行初始化
(3) 使用 other. current 进行初始化
3) 转换构造函数。

此重载仅在满足以下条件时参与重载决议: std:: is_same_v < U, Iter > false 且满足 std:: convertible_to < const U & , Iter > 概念约束。

(C++20 起)

目录

参数

x - 待适配的迭代器
other - 要复制的迭代器适配器

示例

#include <cassert>
#include <concepts>
#include <iterator>
#include <vector>
int main()
{
    std::vector v{0, 1, 2, 3, 4};
    using ReverseIt = std::reverse_iterator<std::vector<int>::const_iterator>;
    ReverseIt i1; // 重载 (1)
    i1 = v.crbegin();
    assert(*i1 == 4);
    ReverseIt i2(i1); // 重载 (2)
    assert(i2[0] == 4);
    int x[]{1, 2, 3};
    auto i3 = std::reverse_iterator<int*>(x + std::size(x)); // 重载 (1)
    i3[0] = -3;
    assert(x[2] == -3);
    std::reverse_iterator<int const*> i4(i3); // 重载 (3): int => const int
    static_assert(std::convertible_to<decltype(i3)::value_type,
                                      decltype(i4)::value_type>);
    // i4[0] = 5; // 错误:对只读位置的赋值
}

缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的C++标准。

缺陷报告 适用标准 发布时行为 正确行为
LWG 235 C++98 重载版本 ( 1 ) 的效果未作规定 已作规定
LWG 1012 C++98 重载版本 ( 1 ) current 进行默认初始化 改为值初始化
LWG 3435 C++20 重载版本 ( 3 ) 未进行约束 已添加约束

参见

赋值另一个 reverse_iterator
(公开成员函数)
创建从参数推断类型的 std::reverse_iterator
(函数模板)