std::ranges::chunk_view<V>::iterator<Const>::operator++,--,+=,-=

出自cppreference.com
< cpp‎ | ranges‎ | chunk view‎ | iterator
 
 
範圍庫
範圍適配器
 
std::ranges::chunk_view
成員函數
用於 input_range 的類
推導指引
outer-iterator
outer-iterator::value_type
inner-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) 等價於:
missing_ = ranges::advance(current_, n_, end_);
return *this;
調用前,表達式 current_ != end_ 必須為 true,否則其行為未定義。
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) 等價於:
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;
如果 x 為正,那麼調用前表達式 ranges::distance(current_, end_) > n_ * (x - 1) 必須為 true(即,非正式地說,所請求的塊應位於底層序列的「內部」)。如果 x 為負,則條件恆成立。
6) 等價於 return *this += -x;

目錄

[編輯] 參數

x - 相對於當前位置的偏移量

[編輯] 返回值

1,3,5,6) *this
2,4) *this 被修改前的副本

[編輯] 示例

[編輯] 參閱

執行迭代器算術
(函數)