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)
template < class U >
reverse_iterator & operator = ( const reverse_iterator < U > & other ) ;
(自 C++17 起为 constexpr)

other. current 赋值给 current

此重载仅当 std:: is_same_v < U, Iter > false ,且同时满足 std:: convertible_to < const U & , Iter > std:: assignable_from < Iter & , const U & > 概念约束时参与重载决议。

(since C++20)

目录

参数

其他 - 用于赋值的迭代器适配器

返回值

* this

示例

#include <iostream>
#include <iterator>
int main()
{
    const int a1[]{0, 1, 2};
    int a2[]{0, 1, 2, 3};
    short a3[]{40, 41, 42};
    std::reverse_iterator<const int*> it1{std::crbegin(a1)};
    it1 = std::reverse_iterator<int*>{std::rbegin(a2)};   // 正确
//  it1 = std::reverse_iterator<short*>{std::rbegin(a3)}; // 编译错误:
                                                          // 不兼容的指针类型
    std::reverse_iterator<const short*> it2{nullptr};
    it2 = std::rbegin(a3); // 正确
//  it2 = std::begin(a3);  // 编译错误:无可用的operator=重载
    std::cout << *it2 << '\n';
}

输出:

42

缺陷报告

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

缺陷报告 适用标准 发布时行为 正确行为
LWG 280 C++98 不允许异构赋值操作 允许
LWG 3435 C++20 转换赋值运算符未受约束 受约束

参见

构造新的 reverse_iterator
(公开成员函数)