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) (seit C++23)
constexpr /*iterator*/ operator ++ ( int ) ;
(2) (seit C++23)
constexpr /*iterator*/ & operator -- ( )
erfordert ranges:: bidirectional_range < Base > ;
(3) (seit C++23)
constexpr /*iterator*/ operator -- ( int )
erfordert ranges:: bidirectional_range < Base > ;
(4) (seit C++23)
constexpr /*iterator*/ & operator + = ( difference_type x )
erfordert ranges:: random_access_range < Base > ;
(5) (seit C++23)
constexpr /*iterator*/ & operator - = ( difference_type x )
erfordert ranges:: random_access_range < Base > ;
(6) (seit C++23)

Erhöht oder verringert den Iterator .

Seien current_ , end_ und n_ die zugrundeliegenden Datenmitglieder des chunk_view::iterator .

1) Entspricht:
missing_ = ranges::advance(current_, n_, end_);
return *this;
Vor dem Aufruf muss der Ausdruck current_ ! = end_ true sein, andernfalls ist das Verhalten undefiniert.
2) Entspricht: auto tmp = * this ; ++* this ; return tmp ; .
3) Entspricht:
ranges::advance(current_, missing_ - n_);
missing_ = 0;
return *this;
4) Entspricht: auto tmp = * this ; --* this ; return tmp ; .
5) Entspricht:
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;
Wenn x positiv ist, muss vor dem Aufruf der Ausdruck ranges:: distance ( current_, end_ ) > n_ * ( x - 1 ) true sein (d.h. informell sollte der angeforderte Block "innerhalb" der zugrundeliegenden Sequenz liegen). Wenn x negativ ist, ist diese Vorbedingung immer erfüllt.
6) Entspricht: return * this + = - x ; .

Inhaltsverzeichnis

Parameter

x - eine Position relativ zum aktuellen Standort

Rückgabewert

1,3,5,6) * this
2,4) eine Kopie von * this die vor der Änderung erstellt wurde

Beispiel

Siehe auch

führt Iterator-Arithmetik aus
(Funktion)