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) |
執行迭代器算術 (函數) |