Синхронизация
Успешное обращение к оператору вызова синхронизируется-с обращением к std::future::get()
или std::shared_future::get()
, которое извлекает хранимое значение или исключение.
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::get()
или std::shared_future::get()
, которое извлекает хранимое значение или исключение.
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();
promise& operator=(promise&&) noexcept;
template
promise(std::allocator_arg_t, Allocator const&);
promise(promise const&) = delete;
promise& operator=(promise const&) = delete;
void swap(promise&) noexcept;
std::future get_future();
void set_value(see description);
void set_exception(std::exception_ptr p);
};
STD::PROMISE
, КОНСТРУКТОР ПО УМОЛЧАНИЮ
Конструирует объект std::promise
.
Объявление
promise();
Результат
Конструирует экземпляр std::promise
, с которым ассоциировал неготовый асинхронный результат типа ResultType
.
Исключения
Исключение типа std::bad_alloc
, если конструктор не смог выделить память для асинхронного результата.
STD::PROMISE
, КОНСТРУКТОР С РАСПРЕДЕЛИТЕЛЕМ
Конструирует экземпляр std::promise, применяя предоставленный распределитель для выделения памяти под ассоциированный асинхронный результат.
Объявление
template
promise(std::allocator_arg_t, Allocator const& alloc);
Результат
Конструирует экземпляр std::promise
, с которым ассоциировал неготовый асинхронный результат типа ResultType
. Память под асинхронный результат выделяется с помощью распределителя alloc
.
Исключения
Любое исключение, возбуждаемое распределителем в случае неудачной попытки выделить память под асинхронный результат.
STD::PROMISE
, ПЕРЕМЕЩАЮЩИЙ КОНСТРУКТОР
Конструирует один объект std::promise
из другого, передавая владение асинхронным результатом от объекта other
вновь сконструированному.
Читать дальше