std::ranges::stride_view<V>::iterator<Const>::operator++,--,+=,-=
来自 cppreference.com
< cpp | ranges | stride view | iterator
constexpr /*iterator*/& operator++(); |
(1) | (自 C++23) |
constexpr void operator++( int ); |
(2) | (自 C++23) |
constexpr /*iterator*/ operator++( int ) requires ranges::forward_range<Base>; |
(3) | (自 C++23) |
constexpr /*iterator*/& operator--() requires ranges::bidirectional_range<Base>; |
(4) | (自 C++23) |
constexpr /*iterator*/ operator--( int ) requires ranges::bidirectional_range<Base>; |
(5) | (自 C++23) |
constexpr /*iterator*/& operator+=( difference_type n ) requires ranges::random_access_range<Base>; |
(6) | (自 C++23) |
constexpr /*iterator*/& operator-=( difference_type n ) requires ranges::random_access_range<Base>; |
(7) | (自 C++23) |
递增或递减 迭代器.
设 current_
、end_
、stride_
和 missing_
是 迭代器 的数据成员。
2) 等同于 ++*this;.
3) 等同于 auto tmp = *this; ++*this; return tmp;.
4) 等同于
ranges::advance(current_, missing_ - stride_); missing_ = 0; return *this;
5) 等同于 auto tmp = *this; --*this; return tmp;.
6) 等同于
if (n > 0) { ranges::advance(current_, stride_ * (n - 1)); missing_ = ranges::advance(current_, stride_, end_); } else if (n < 0) { ranges::advance(current_, stride_ * n + missing_); missing_ = 0; } return *this;
如果 n > 0,则在调用此函数之前,ranges::distance(current_, end_) 必须大于 stride_ * (n - 1).
请注意,如果 n < 0,则 ranges::distance(current_, end_) 始终大于(非正数)stride_ * (n - 1).7) 等同于 return *this += -n;
内容 |
[编辑] 参数
n | - | 相对于当前位置的位置 |
[编辑] 返回值
1,4,6,7) *this
2) (无)
3,5) 更改前创建的 *this 的副本
[编辑] 例子
本节内容不完整 原因: 没有例子 |
[编辑] 参见
(C++23) |
执行迭代器算术运算 (函数) |