std::ranges::chunk_view<V>::iterator<Const>::operator++,--,+=,-=
来自 cppreference.com
< cpp | ranges | chunk view | iterator
constexpr /*iterator*/& operator++(); |
(1) | (自 C++23 起) |
constexpr /*iterator*/ operator++( int ); |
(2) | (自 C++23 起) |
constexpr /*iterator*/& operator--() requires ranges::bidirectional_range<Base>; |
(3) | (自 C++23 起) |
constexpr /*iterator*/ operator--( int ) requires ranges::bidirectional_range<Base>; |
(4) | (自 C++23 起) |
constexpr /*iterator*/& operator+=( difference_type x ) requires ranges::random_access_range<Base>; |
(5) | (自 C++23 起) |
constexpr /*iterator*/& operator-=( difference_type x ) requires ranges::random_access_range<Base>; |
(6) | (自 C++23 起) |
前进或后退 迭代器.
令 current_
、end_
和 n_
为 数据成员 的基础 chunk_view::iterator
.
1) 等同于在调用之前,表达式 current_ != end_ 必须为 true,否则行为未定义。
missing_ = ranges::advance(current_, n_, end_); return *this;
2) 等同于: auto tmp = *this; ++*this; return tmp;.
3) 等同于
ranges::advance(current_, missing_ - n_); missing_ = 0; return *this;
4) 等同于: auto tmp = *this; --*this; return tmp;.
5) 等同于如果 x 为正数,则在调用之前,表达式 ranges::distance(current_, end_) > n_ * (x - 1) 必须为 true(即,非正式地说,请求的块应该“在”基础序列中)。如果 x 为负数,则此先决条件始终满足。
if (x > 0) { ranges::advance(current_, n_ * (x - 1)); missing_ = ranges::advance(current_, n_, end_); } else if (x < 0) { ranges::advance(current_, n_ * x + missing_); missing_ = 0; } return *this;
6) 等同于: return *this += -x;.
内容 |
[编辑] 参数
x | - | 相对于当前位置的相对位置 |
[编辑] 返回值
1,3,5,6) *this
2,4) 在更改之前创建的 *this 的副本
[编辑] 示例
本节内容不完整 原因:没有示例 |
[编辑] 另请参阅
(C++23) |
执行迭代器算术运算 (函数) |