Range Pipelining avec des conteneurs temporaires utilisant Range-V3
Problème :
Vous avez un plage d'éléments (src) et une fonction tierce (f) qui prend un élément de la plage en entrée et renvoie un vecteur. Vous souhaitez transformer chaque élément de la plage en utilisant f et aplatir les vecteurs résultants en une seule plage. Cependant, utiliser directement view::transform et view::join ne fonctionnera pas car les vues ne peuvent pas être créées pour les conteneurs temporaires.
Solution :
Pour prendre en charge de tels pipelines , range-v3 introduit l'opérateur vues :: cache1. Cet opérateur vous permet de stocker les résultats d'une vue dans un conteneur temporaire puis de créer une vue de ce conteneur. En incluant views::cache1 dans le pipeline, vous pouvez créer une vue des vecteurs aplatis :
auto rng = src | views::transform(f) | views::cache1 | views::join;
Exemple de code :
L'exemple de code suivant montre comment utiliser views::cache1 pour créer un pipeline de plage qui transforme et aplatit les éléments d'une plage :
<code class="cpp">#include <range/v3/view.hpp> #include <range/v3/algorithm.hpp> #include <vector> std::vector<std::string> f(int i) { return std::vector<std::string>(i, char('a' + i)); } int main() { auto rng = views::iota(0, 4) | views::transform([](int i) { return f(i); }) | views::cache1 | views::join('-'); check_equal(rng, {'-', 'b', '-', 'c', 'c', '-', 'd', 'd', 'd'}); CPP_assert(input_range<decltype(rng)>); CPP_assert(!range<const decltype(rng)>); CPP_assert(!forward_range<decltype(rng)>); CPP_assert(!common_range<decltype(rng)>); return 0; }</code>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!