std:: generate_n
|
Определено в заголовочном файле
<algorithm>
|
||
|
template
<
class
OutputIt,
class
Size,
class
Generator
>
OutputIt generate_n ( OutputIt first, Size count, Generator g ) ; |
(1) | (constexpr начиная с C++20) |
|
template
<
class
ExecutionPolicy,
class
ForwardIt,
class
Size,
class
Generator
>
|
(2) | (начиная с C++17) |
|
std:: is_execution_policy_v < std:: decay_t < ExecutionPolicy >> равно true . |
(до C++20) |
|
std:: is_execution_policy_v < std:: remove_cvref_t < ExecutionPolicy >> равно true . |
(начиная с C++20) |
Если
Size
не является
преобразуемым
в
целочисленный тип
, программа является некорректной.
Содержание |
Параметры
| first | - | начало диапазона элементов для генерации | ||||||
| count | - | количество генерируемых элементов | ||||||
| policy | - | политика выполнения, которая будет использоваться execution policy to use | ||||||
| g | - |
функциональный объект-генератор, который будет вызываться.
Сигнатура функции должна быть эквивалентна следующей:
Тип Ret должен быть таким, чтобы объект типа OutputIt мог быть разыменован и ему присвоено значение типа Ret . |
||||||
| Требования к типам | ||||||||
-
OutputIt
должен удовлетворять требованиям
LegacyOutputIterator
.
|
||||||||
-
ForwardIt
должен удовлетворять требованиям
LegacyForwardIterator
.
|
||||||||
Возвращаемое значение
Итератор на элемент, следующий за последним присвоенным элементом, если count > 0 , first в противном случае.
Сложность
Ровно std:: max ( 0 , count ) вызовов функции g ( ) и операций присваивания.
Исключения
Перегрузка с параметром шаблона с именем
ExecutionPolicy
сообщает об ошибках следующим образом:
-
Если выполнение функции, вызванной как часть алгоритма, выбрасывает исключение и
ExecutionPolicyявляется одним из стандартных политик , std::terminate вызывается. Для любой другойExecutionPolicyповедение определяется реализацией. - Если алгоритму не удается выделить память, std::bad_alloc выбрасывается.
Возможная реализация
template<class OutputIt, class Size, class Generator> constexpr // начиная с C++20 OutputIt generate_n(OutputIt first, Size count, Generator g) { for (Size i = 0; i < count; ++i, ++first) *first = g(); return first; } |
Пример
#include <algorithm> #include <functional> #include <iostream> #include <iterator> #include <random> int main() { std::mt19937 rng; // конструктор по умолчанию, заполнен фиксированным зерном std::generate_n(std::ostream_iterator<std::mt19937::result_type>(std::cout, " "), 5, std::ref(rng)); std::cout << '\n'; }
Вывод:
3499211612 581869302 3890346734 3586334585 545404204
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Применяется к | Поведение в опубликованной версии | Корректное поведение |
|---|---|---|---|
| LWG 426 | C++98 |
требование сложности было "ровно
count
вызовов
или присваиваний", что некорректно если count отрицательный |
вызовы или присваивания не производятся
если count неположительный |
| LWG 865 | C++98 |
позиция первого элемента после
диапазона генерации не возвращалась |
возвращается |
Смотрите также
|
копирует-присваивает заданное значение N элементам в диапазоне
(шаблон функции) |
|
|
присваивает результаты последовательных вызовов функции каждому элементу в диапазоне
(шаблон функции) |
|
|
(C++20)
|
сохраняет результат N применений функции
(функциональный объект алгоритма) |