命名空间
变体
操作

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

基础迭代器被分配了 other 的基础迭代器的值,即 other.base().

只有当 UIter 不是相同类型,并且 std::convertible_to<const U&, Iter>std::assignable_from<Iter&, const U&> 被建模时,此重载才会参与重载解析。

(自 C++20 起)

内容

[编辑] 参数

other - 要分配的迭代器适配器

[编辑] 返回值

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

输出

42

[编辑] 缺陷报告

以下更改行为的缺陷报告已追溯应用到之前发布的 C++ 标准。

DR 应用于 已发布的行为 正确的行为
LWG 280 C++98 可以构造一个 std::reverse_iterator,但不能从
具有不同基础迭代器类型的另一个 std::reverse_iterator 进行分配
还允许分配
LWG 3435 C++20 转换赋值运算符未受到约束 受约束

[编辑] 另请参见

构造一个新的迭代器适配器
(公共成员函数) [编辑]