Namespaces
Variants

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

From cppreference.net
Ranges library
Range adaptors
std::ranges::chunk_view
Member functions
Classes for input_range s
Deduction guides
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以降)

iterator を進める、または戻します。

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 のコピー

関連項目

イテレータ演算を実行する
(関数)