std::ranges:: uninitialized_value_construct_n
|
Definido en el encabezado
<memory>
|
||
|
Firma de llamada
|
||
|
template
<
no-throw-forward-iterator
I
>
requires
std::
default_initializable
<
std::
iter_value_t
<
I
>>
|
(desde C++20)
(constexpr desde C++26) |
|
Construye objetos de tipo
std::
iter_value_t
<
I
>
en el área de memoria no inicializada
first
+
[
0
,
count
)
mediante
inicialización por valor
, como si fuera
return
ranges::
uninitialized_value_construct
(
std::
counted_iterator
(
first, count
)
,
std::
default_sentinel
)
.
base
(
)
;
Si se lanza una excepción durante la inicialización, los objetos ya construidos se destruyen en un orden no especificado.
Las entidades similares a funciones descritas en esta página son algorithm function objects (conocidas informalmente como niebloids ), es decir:
- No se pueden especificar listas de argumentos de plantilla explícitas al llamar a cualquiera de ellos.
- Ninguno de ellos es visible para la búsqueda dependiente de argumento .
- Cuando cualquiera de ellos es encontrado mediante la búsqueda no calificada normal como el nombre a la izquierda del operador de llamada a función, la búsqueda dependiente de argumento queda inhibida.
Contenidos |
Parámetros
| first | - | el inicio del rango de elementos a inicializar |
| count | - | el número de elementos a construir |
Valor de retorno
Como se describió anteriormente.
Complejidad
Lineal en count .
Excepciones
Cualquier excepción lanzada durante la construcción de los elementos en el rango de destino.
Notas
Una implementación puede mejorar la eficiencia de
ranges::uninitialized_value_construct_n
, por ejemplo utilizando
ranges::fill_n
, si el tipo de valor del rango es un
CopyAssignable
TrivialType
.
| Macro de prueba de características | Valor | Estándar | Característica |
|---|---|---|---|
__cpp_lib_raw_memory_algorithms
|
202411L
|
(C++26) | constexpr para algoritmos de memoria especializados |
Implementación posible
struct uninitialized_value_construct_n_fn { template<no-throw-forward-iterator I> requires std::default_initializable<std::iter_value_t<I>> constexpr I operator()(I first, std::iter_difference_t<I> count) const { auto iter = std::counted_iterator(first, count); return ranges::uninitialized_value_construct(iter, std::default_sentinel).base(); } }; inline constexpr uninitialized_value_construct_n_fn uninitialized_value_construct_n{}; |
Ejemplo
#include <iostream> #include <memory> #include <string> int main() { struct S { std::string m{"█▓▒░ █▓▒░ █▓▒░ "}; }; constexpr int n{4}; alignas(alignof(S)) char out[n * sizeof(S)]; try { auto first{reinterpret_cast<S*>(out)}; auto last = std::ranges::uninitialized_value_construct_n(first, n); auto count{1}; for (auto it{first}; it != last; ++it) std::cout << count++ << ' ' << it->m << '\n'; std::ranges::destroy(first, last); } catch (...) { std::cout << "Exception!\n"; } // Para tipos escalares, uninitialized_value_construct_n // inicializa a cero el área de memoria no inicializada dada. int v[]{1, 2, 3, 4, 5, 6, 7, 8}; std::cout << ' '; for (const int i : v) std::cout << i << ' '; std::cout << "\n "; std::ranges::uninitialized_value_construct_n(std::begin(v), std::size(v)); for (const int i : v) std::cout << i << ' '; std::cout << '\n'; }
Salida:
1 █▓▒░ █▓▒░ █▓▒░ 2 █▓▒░ █▓▒░ █▓▒░ 3 █▓▒░ █▓▒░ █▓▒░ 4 █▓▒░ █▓▒░ █▓▒░ 1 2 3 4 5 6 7 8 0 0 0 0 0 0 0 0
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 3870 | C++20 | este algoritmo podría crear objetos en un almacenamiento const | se mantiene no permitido |
Véase también
|
construye objetos mediante
value-initialization
en un área de memoria no inicializada, definida por un rango
(objeto función algoritmo) |
|
|
construye objetos mediante
default-initialization
en un área de memoria no inicializada, definida por un rango
(objeto función algoritmo) |
|
|
construye objetos mediante
default-initialization
en un área de memoria no inicializada, definida por un inicio y un contador
(objeto función algoritmo) |
|
|
(C++17)
|
construye objetos mediante
value-initialization
en un área de memoria no inicializada, definida por un inicio y un contador
(plantilla de función) |