std::ranges:: uninitialized_fill_n
|
Определено в заголовке
<memory>
|
||
|
Сигнатура вызова
|
||
|
template
<
no-throw-forward-range
I,
class
T
>
requires
std::
constructible_from
<
std::
iter_value_t
<
I
>
,
const
T
&
>
|
(начиная с C++20)
(constexpr начиная с C++26) |
|
Копирует
value
в неинициализированную область памяти
first
+
[
0
,
count
)
как если бы
return
ranges::
uninitialized_fill
(
std::
counted_iterator
(
first, count
)
,
std::
default_sentinel
, value
)
.
base
(
)
;
Если во время инициализации возникает исключение, уже созданные объекты уничтожаются в неопределенном порядке.
Описываемые на этой странице функциональные сущности являются algorithm function objects (неформально известными как niebloids ), то есть:
- Явные списки аргументов шаблона не могут быть указаны при вызове любого из них.
- Ни один из них не видим для argument-dependent lookup .
- Когда любой из них найден с помощью normal unqualified lookup как имя слева от оператора вызова функции, argument-dependent lookup блокируется.
Содержание |
Параметры
| first | - | начало диапазона элементов для инициализации |
| count | - | количество элементов для создания |
| value | - | значение для создания элементов |
Возвращаемое значение
Как описано выше.
Сложность
Линейно по count .
Исключения
Любое исключение, выброшенное при конструировании элементов в целевом диапазоне.
Примечания
Реализация может повысить эффективность
ranges::uninitialized_fill_n
, например, используя
ranges::fill_n
, если тип значения выходного диапазона является
TrivialType
.
| Макрос тестирования возможностей | Значение | Стандарт | Функция |
|---|---|---|---|
__cpp_lib_raw_memory_algorithms
|
202411L
|
(C++26) | constexpr для специализированных алгоритмов работы с памятью |
Возможная реализация
struct uninitialized_fill_n_fn { template<no-throw-forward-range I, class T> requires std::constructible_from<std::iter_value_t<I>, const T&> I operator()(I first, std::iter_difference_t<I> n, const T& x) const { I rollback{first}; try { for (; n-- > 0; ++first) ranges::construct_at(std::addressof(*first), x); return first; } catch (...) // откат: уничтожить созданные элементы { for (; rollback != first; ++rollback) ranges::destroy_at(std::addressof(*rollback)); throw; } } }; inline constexpr uninitialized_fill_n_fn uninitialized_fill_n{}; |
Пример
#include <iostream> #include <memory> #include <string> int main() { constexpr int n{3}; alignas(alignof(std::string)) char out[n * sizeof(std::string)]; try { auto first{reinterpret_cast<std::string*>(out)}; auto last = std::ranges::uninitialized_fill_n(first, n, "cppreference"); for (auto it{first}; it != last; ++it) std::cout << *it << '\n'; std::ranges::destroy(first, last); } catch (...) { std::cout << "Exception!\n"; } }
Вывод:
cppreference cppreference cppreference
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 3870 | C++20 | этот алгоритм может создавать объекты в const хранилище | оставлено запрещенным |
Смотрите также
|
(C++20)
|
копирует объект в неинициализированную область памяти, определяемую диапазоном
(функциональный объект алгоритма) |
|
копирует объект в неинициализированную область памяти, определяемую началом и количеством
(шаблон функции) |