std::counted_iterator<I>:: counted_iterator
From cppreference.net
<
cpp
|
iterator
|
counted iterator
C++
Iterator library
| Iterator concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator primitives | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Algorithm concepts and utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Indirect callable concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Common algorithm requirements | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator adaptors | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::counted_iterator
| Member functions | ||||
|
counted_iterator::counted_iterator
|
||||
| Non-member functions | ||||
|
(C++20)
(C++20)
|
||||
|
(C++20)
|
||||
|
(C++20)
|
||||
|
(C++20)
|
||||
|
(C++20)
|
||||
|
(C++20)
|
||||
|
(C++20)
|
||||
| Helper classes | ||||
|
constexpr
counted_iterator
(
)
requires
std::
default_initializable
<
I
>
=
default
;
|
(1) | (depuis C++20) |
|
constexpr
counted_iterator
(
I x,
std::
iter_difference_t
<
I
>
n
)
;
|
(2) | (depuis C++20) |
|
template
<
class
I2
>
requires
std::
convertible_to
<
const
I2
&
, I
>
|
(3) | (depuis C++20) |
Construit un nouvel adaptateur d'itérateur.
1)
Constructeur par défaut.
Initialise à la valeur
l'itérateur sous-jacent et initialise la
longueur
sous-jacente avec
0
. Les opérations sur l'itérateur résultant ont un comportement défini si et seulement si les opérations correspondantes sur un
I
initialisé à la valeur ont également un comportement défini.
2)
L'itérateur sous-jacent est initialisé avec
std
::
move
(
x
)
et la
longueur
sous-jacente est initialisée avec
n
. Le comportement est indéfini si
n
est négatif.
3)
L'itérateur sous-jacent et la
longueur
sont initialisés avec ceux de
other
.
Paramètres
| x | - | itérateur à adapter |
| n | - | distance jusqu'à la fin |
| other | - | adaptateur d'itérateur à convertir |
Exemple
Exécuter ce code
#include <algorithm> #include <initializer_list> #include <iostream> #include <iterator> int main() { static constexpr auto pi = {3, 1, 4, 1, 5, 9, 2}; // (1) constructeur par défaut : constexpr std::counted_iterator<std::initializer_list<int>::iterator> i1{}; static_assert(i1 == std::default_sentinel); static_assert(i1.count() == 0); // (2) initialise respectivement l'itérateur et la longueur : constexpr std::counted_iterator<std::initializer_list<int>::iterator> i2{ pi.begin(), pi.size() - 2 }; static_assert(i2.count() == 5); static_assert(*i2 == 3 && i2[1] == 1); // (3) constructeur de conversion : std::counted_iterator<std::initializer_list<const int>::iterator> i3{i2}; std::ranges::copy(i3, std::default_sentinel, std::ostream_iterator<const int>{std::cout, " "}); }
Sortie :
3 1 4 1 5
Voir aussi
assigne un autre
counted_iterator
(fonction membre publique) |