Namespaces
Variants

std::ranges::chunk_view<V>:: outer-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 /*outer-iterator*/
(depuis C++23)
( exposition uniquement* )

Le type de retour de chunk_view::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 >

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)
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 de chunks restants
(fonction)

Classes imbriquées

(C++23)
le type de valeur de /*output-iterator*/
(classe membre publique)

Exemple

#include <iostream>
#include <iterator>
#include <ranges>
#include <sstream>
int main()
{
    const std::string source{"ABCDEFGHIJ"};
    auto letters = std::istringstream{source};
    auto chunks = std::ranges::istream_view<char>(letters)
                | std::views::chunk(4);
    for (auto outer_iter = chunks.begin(); outer_iter != std::default_sentinel;
         ++outer_iter)
    {
        auto chunk = *outer_iter; // 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';
    // Même sortie en utilisant les boucles for à portée
    auto letters2 = std::istringstream{source};
    auto chunks2 = std::ranges::istream_view<char>(letters2)
                 | std::views::chunk(4);
    for (auto chunk : chunks2)
    {
        std::cout << '[';
        for (auto ch : chunk)
            std::cout << ch;
        std::cout << "] ";
    }
    std::cout << '\n';
}

Sortie :

[ABCD] [EFGH] [IJ]
[ABCD] [EFGH] [IJ]

Références

  • Norme C++23 (ISO/IEC 14882:2024) :
  • 26.7.28.3 Classe chunk_view::outer-iterator [range.chunk.outer.iter]

Voir aussi