std::reverse_iterator<Iter>::operator=
来自 cppreference.cn
template< class U > reverse_iterator& operator=( const reverse_iterator<U>& other ); |
(自 C++17 起为 constexpr) | |
仅若 std::is_same_v<U, Iter> 为 false,且 std::convertible_to<const U&, Iter> 和 std::assignable_from<Iter&, const U&> 均被建模,此重载才会参与重载决议。 |
(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)}; // 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
[编辑] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 280 | C++98 | 异构赋值是不允许的 | 允许 |
LWG 3435 | C++20 | 转换赋值运算符未被约束 | 已受约束 |
[编辑] 参阅
构造一个新的 reverse_iterator (公开成员函数) |