STD::PACKAGED_TASK::VALID
, ФУНКЦИЯ-ЧЛЕН
Проверяет, ассоциированы ли с *this
задача и асинхронный результат.
bool valid() const noexcept;
true
, если с *this
ассоциированы задача и асинхронный результат, иначе false
.
Нет.
STD::PACKAGED_TASK::OPERATOR()
, ОПЕРАТОР ВЫЗОВА
Вызывает задачу, ассоциированную с экземпляром std::packaged_task
, и сохраняет возвращенное ей значение или исключение в ассоциированном асинхронном результате.
void operator()(ArgTypes... args);
С *this
ассоциирована задача.
Вызывает ассоциированную задачу, как если бы было выполнено предложение INVOKE(func, args...)
. Если вызов завершается нормально, то сохраняет возвращенное значение в асинхронном результате, ассоциированном с *this
. Если задача возбуждает исключение, то сохраняет это исключение в асинхронном результате, ассоциированном с *this
.
Асинхронный результат, ассоциированный с *this
, готов и содержит значение или исключение. Все потоки, ожидающие асинхронного результата, разблокируются.
Исключение типа std::future_error
с кодом ошибки std::future_errc::promise_already_satisfied
, если в асинхронном результате уже находится значение или исключение.
Успешное обращение к оператору вызова синхронизируется-с обращением к std::future
или std::shared_future
, которое извлекает хранимое значение или исключение.
STD::PACKAGED_TASK::MAKE_READY_AT_THREAD_EXIT
, ФУНКЦИЯ-ЧЛЕН
Вызывает задачу, ассоциированную с экземпляром std::packaged_task
, и сохраняет возвращенное ей значение или исключение в ассоциированном асинхронном результате, но не делает этот результат готовым раньше момента завершения потока.
void make_ready_at_thread_exit(ArgTypes... args);
С *this
ассоциирована задача.
Вызывает ассоциированную задачу, как если бы было выполнено предложение INVOKE(func, args...)
. Если вызов завершается нормально, то сохраняет возвращенное значение в асинхронном результате, ассоциированном с *this
. Если задача возбуждает исключение, то сохраняет это исключение в асинхронном результате, ассоциированном с *this
. Планирует перевод ассоциированного асинхронного результата в состояние готовности в момент завершения потока.
Асинхронный результат, ассоциированный с *this
, содержит значение или исключение, но не является готовым до завершения текущего потока. Все потоки, ожидающие асинхронного результата, будут разблокированы, когда текущий поток завершится.
Исключение типа std::future_error
с кодом ошибки std::future_errc::promise_already_satisfied
, если в асинхронном результате уже находится значение или исключение. Исключение типа std::future_error
с кодом ошибки std::future_errc::no_state
, если с *this
не ассоциировано асинхронное состояние.
Завершение потока, в котором была успешно вызвала функция make_ready_at_thread_exit()
, синхронизируется-с обращением к std::future
или std::shared_future
, которое извлекает хранимое значение или исключение.
D.4.4. Шаблон класса std::promise
Шаблон класса std::promise
предоставляет средства для установки асинхронного результата, который может быть получен в другом потоке с помощью экземпляра std::future
.
Параметр ResultType
— это тип значения, сохраняемого в асинхронном результате.
Объект std::future
, ассоциированный с асинхронным результатом конкретного экземпляра std::promise
, можно получить путем обращения к функции-члену get_future()
. В асинхронный результат записывается либо значение типа ResultType
функцией-членом set_value()
, либо исключение функцией-членом set_exception()
.
Экземпляры std::promise
удовлетворяют требованиям концепций MoveConstructible
и MoveAssignable
, но не CopyConstructible
или CopyAssignable
.
template
class promise {
public:
promise();
promise(promise&&) noexcept;
~promise();