std::ranges::chunk_view<V>:: iterator <Const>:: operator++,--,+=,-=
From cppreference.net
<
cpp
|
ranges
|
chunk view
|
iterator
C++
Ranges library
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
std::ranges::chunk_view
| Member functions | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
(C++26)
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
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:
Vor dem Aufruf muss der Ausdruck
current_
!
=
end_
true
sein, andernfalls ist das Verhalten undefiniert.
missing_ = ranges::advance(current_, n_, end_); return *this;
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:
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.
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)
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
|
Dieser Abschnitt ist unvollständig
Grund: Kein Beispiel |
Siehe auch
|
(C++23)
|
führt Iterator-Arithmetik aus
(Funktion) |