std::experimental:: to_array
From cppreference.net
<
cpp
|
experimental
|
Definido en el encabezado
<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) | |
Crea un std::array a partir del array incorporado a . Los elementos del std::array se inicializan por copia a partir del elemento correspondiente de a .
Contenidos |
Parámetros
| a | - | el array incorporado que se utilizará para inicializar el std::array |
Valor de retorno
Un objeto std::array cuyos elementos son copy-initialized desde el elemento correspondiente de a .
Implementación posible
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>{}); } |
Ejemplo
Ejecutar este código
#include <cassert> #include <cstdlib> #include <experimental/array> #include <unistd.h> // mkstemp(3) que funciona 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); }
Véase también
|
(library fundamentals TS v2)
|
crea un objeto
std::array
cuyo tamaño y opcionalmente el tipo de elemento se deducen de los argumentos
(plantilla de función) |