Namespaces
Variants

std::ranges::chunk_view<V>:: inner-iterator

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
class /*inner-iterator*/
(depuis C++23)
( exposition uniquement* )

Le type de retour de chunk_view:: outer-iterator ::value_type::begin si V modélise input_range .

Table des matières

Types membres

Type de membre Définition
iterator_concept std:: input_iterator_tag
difference_type ranges:: range_difference_t < V >
value_type ranges:: range_value_t < V >

Membres de données

Objet membre Définition
parent_ (privé) Un pointeur vers l'"objet parent" de type ranges:: chunk_view * .
( objet membre d'exposition uniquement* )

Fonctions membres

construit un itérateur
(fonction membre publique)
(C++23)
assigne par déplacement un autre itérateur
(fonction membre publique)
(C++23)
retourne un itérateur vers l'élément courant
(fonction membre publique)
(C++23)
accède à l'élément
(fonction membre publique)
(C++23)
incrémente l'itérateur
(fonction membre publique)

Fonctions non membres

(C++23)
compare l'itérateur avec default sentinel
(fonction)
(C++23)
calcule le nombre d'éléments restants
(fonction)
(C++23)
convertit le résultat du déréférencement de l'itérateur sous-jacent en son type de référence rvalue associé
(fonction)
(C++23)
échange les objets pointés par deux itérateurs sous-jacents
(fonction)

Exemple

#include <iostream>
#include <iterator>
#include <ranges>
#include <sstream>
int main()
{
    auto letters = std::istringstream{"ABCDEFGHIJK"};
    auto chunks = std::ranges::istream_view<char>(letters)
                | std::views::chunk(4);
    for (auto chunk : chunks)
    {
        // chunk est un objet de type chunk_view::outer_iterator::value_type
        std::cout << '[';
        for (auto inner_iter = chunk.begin(); inner_iter != std::default_sentinel;
             ++inner_iter)
            std::cout << *inner_iter;
        std::cout << "] ";
    }
    std::cout << '\n';
}

Sortie :

[ABCD] [EFGH] [IJK]

Références

  • Norme C++23 (ISO/CEI 14882:2024) :
  • 26.7.28.5 Classe chunk_view:: inner-iterator [range.chunk.inner.iter]

Voir aussi