std::reverse_iterator<Iter>::operator=
来自 cppreference.com
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().
只有当 |
(自 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 | 转换赋值运算符未受到约束 | 受约束 |
[编辑] 另请参见
构造一个新的迭代器适配器 (公共成员函数) |