Maison >développement back-end >C++ >Comment initialiser élégamment un « std::array » avec des types non constructibles par défaut ?
Initialisation élégante de std::array avec un type non constructible par défaut
Initialisation d'un std::array avec un type autre que celui par défaut Le type d’élément constructible peut être une tâche fastidieuse. Répéter manuellement la valeur n fois est inefficace et sujet aux erreurs pour un grand n.
Pour résoudre ce problème, une approche plus élégante consiste à utiliser un type de séquence et un générateur. L'idée clé est de créer une séquence d'indices de 0 à n-1, puis d'utiliser une fonction pour appliquer à plusieurs reprises une valeur à chaque index.
Voici une implémentation :
<code class="cpp">template<typename T, int...N> auto repeat(T value, seq<N...>) -> std::array<T, sizeof...(N)> { // Unpack N, repeating `value` sizeof...(N) times // Note that (X, value) evaluates to value return {(N, value)...}; }</code>
Pour initialiser un std::array en utilisant cette approche :
<code class="cpp">template<typename T, int N> void f(T value) { // genseq_t<N> is seq<0,1,...N-1> std::array<T, N> items = repeat(value, genseq_t<N>{}); }</code>
De plus, les définitions suivantes sont utilisées :
<code class="cpp">template<int ... N> struct seq { using type = seq<N...>; static const std::size_t size = sizeof ... (N); template<int I> struct push_back : seq<N..., I> {}; }; template<int N> struct genseq : genseq<N-1>::type::template push_back<N-1> {}; template<> struct genseq<0> : seq<> {}; template<int N> using genseq_t = typename genseq<N>::type;</code>
Cette solution fournit un moyen efficace et élégant d'initialiser std::array avec des types non constructibles par défaut, quelle que soit la valeur de n.
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!