Namespaces
Variants

std::experimental:: to_array

From cppreference.net
Défini dans l'en-tête <experimental/array>
template < class T, std:: size_t N >
constexpr std:: array < std:: remove_cv_t < T > , N > to_array ( T ( & a ) [ N ] ) ;
(library fundamentals TS v2)

Crée un std::array à partir du tableau natif a . Les éléments du std::array sont copie-initialisés à partir de l'élément correspondant de a .

Table des matières

Paramètres

a - le tableau intégré à utiliser pour initialiser le std::array

Valeur de retour

Un objet std::array dont les éléments sont copie-initialisés à partir de l'élément correspondant de a .

Implémentation possible

namespace detail
{
    template<class T, std::size_t N, std::size_t... I>
    constexpr std::array<std::remove_cv_t<T>, N>
        to_array_impl(T (&a)[N], std::index_sequence<I...>)
    {
        return { {a[I]...} };
    }
}
template<class T, std::size_t N>
constexpr std::array<std::remove_cv_t<T>, N> to_array(T (&a)[N])
{
    return detail::to_array_impl(a, std::make_index_sequence<N>{});
}

Exemple

#include <cassert>
#include <cstdlib>
#include <experimental/array>
#include <unistd.h>
// mkstemp(3) qui fonctionne
template<std::size_t N>
int tempfd(char const (&tmpl)[N])
{
    auto s = std::experimental::to_array(tmpl);
    int fd = mkstemp(s.data());
    if (fd != -1)
        unlink(s.data());
    return fd;
}
int main()
{
    int fd = tempfd("/tmp/test.XXXXXX");
    int rt = close(fd);
    assert(rt == 0);
}

Voir aussi

(library fundamentals TS v2)
crée un objet std::array dont la taille et optionnellement le type d'élément sont déduits des arguments
(modèle de fonction)