命名空间
变体
操作

std::reverse_iterator<Iter>::operator=

来自 cppreference.cn
 
 
迭代器库
迭代器概念
迭代器原语
算法概念和工具
间接可调用概念
通用算法要求
(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)
 
 
template< class U >
reverse_iterator& operator=( const reverse_iterator<U>& other );
(constexpr 自 C++17 起)

other.current 赋值给 current

仅当 std::is_same_v<U, Iter>falsestd::convertible_to<const U&, Iter>std::assignable_from<Iter&, const U&> 均被建模时,此重载才参与重载解析。

(自 C++20 起)

目录

[edit] 参数

other - 要赋值的迭代器适配器

[edit] 返回值

*this

[edit] 示例

#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)};   // OK
//  it1 = std::reverse_iterator<short*>{std::rbegin(a3)}; // Compilation error:
                                                          // incompatible pointer types
    std::reverse_iterator<const short*> it2{nullptr};
    it2 = std::rbegin(a3); // OK
//  it2 = std::begin(a3);  // Compilation error: no viable operator= overload
    std::cout << *it2 << '\n';
}

输出

42

[edit] 缺陷报告

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

DR 应用于 已发布行为 正确行为
LWG 280 C++98 不允许异构赋值 允许
LWG 3435 C++20 转换赋值运算符未受约束 已约束

[edit] 参见

构造一个新的 reverse_iterator
(公共成员函数) [编辑]