Объявление
promise(promise&& other) noexcept;
Результат
Конструирует новый экземпляр std::promise
.
Постусловия
Асинхронный результат, который был ассоциирован с объектом other
до вызова конструктор, ассоциируется с вновь сконструированным объектом std::promise
. С объектом other
больше не ассоциирован никакой асинхронный результат.
Исключения
Нет.
STD::PROMISE
, ПЕРЕМЕЩАЮЩИЙ ОПЕРАТОР ПРИСВАИВАНИЯ
Передает владение асинхронным результатом, ассоциированным с объектом std::promise
, другому объекту.
Объявление
promise& operator=(promise&& other) noexcept;
Результат
Передает владение асинхронным результатом, ассоциированным с *this
. Если с *this
уже был ассоциирован асинхронный результат, то результат становится готов , причем в него помещается исключение std::future_error
с кодом ошибки std::future_errc::broken_promise
.
Постусловия
Асинхронный результат, который был ассоциирован с объектом other
до вызова перемещающего оператора присваивания, ассоциируется с *this
. С объектом other
больше не ассоциирован никакой асинхронный результат.
Возвращаемое значение
*this
Исключения
Нет.
STD::PROMISE::SWAP
, ФУНКЦИЯ-ЧЛЕН
Обменивает владение асинхронными результатами, ассоциированными с двумя объектами std::promise
.
Объявление
void swap(promise& other);
Результат
Обменивает владение асинхронными результатами, ассоциированными с объектами other
и *this
.
Постусловия
Асинхронный результат, который был ассоциирован с объектом other
до вызова swap
(если таковой действительно был), ассоциируется с *this
. Асинхронный результат, который был ассоциирован с объектом *this
до вызова swap
(если таковой действительно был), ассоциируется с other
.
Исключения
Нет.
STD::PROMISE
, ДЕСТРУКТОР
Уничтожает объект std::promise
.
Объявление
~promise();
Результат
Уничтожает *this
. Если с *this
ассоциирован асинхронный результат и в этом результате не хранится задача или исключение, то результат становится готов , причем в него помещается исключение std::future_error
с кодом ошибки std::future_errc::broken_promise
.
Исключения
Нет.
STD::PROMISE::GET_FUTURE
, ФУНКЦИЯ-ЧЛЕН
Извлекает экземпляр std::future
для асинхронного результата, ассоциированного с *this
.
Объявление
std::future get_future();
Предусловия
С *this
ассоциировал асинхронный результат.
Возвращаемое значение
Экземпляр std::future
для асинхронного результата, ассоциированного с *this
.
Исключения
Исключение типа std::future_error
с кодом ошибки std::future_errc::future_already_retrieved
, если объект std::future
уже был получен для этого асинхронного результата с помощью предшествующего обращения к get_future()
.
STD::PROMISE::SET_VALUE
, ФУНКЦИЯ-ЧЛЕН
Сохраняет значение в асинхронном результате, ассоциированном с *this
.
Объявление
void promise::set_value();
void promise::set_value(R& r);
void promise::set_value(R const& r);
void promise::set_value(R&& r);
Предусловия
С *this
ассоциирован асинхронный результат.
Результат
Сохраняет r
в асинхронном результате, ассоциированном с *this
, если ResultType
— не void
.
Постусловия
Асинхронный результат, ассоциированный с *this
, готов и содержит значение. Все потоки, ожидающие асинхронного результата, разблокируются.
Исключения
Исключение типа std::future_error
с кодом ошибки std::future_errc::promise_already_satisfied
, если в асинхронном результате уже находится значение или исключение. Любое исключение, возбужденное копирующим или перемещающим конструктором r
.
Синхронизация
Обращения к set_value()
, set_value_at_thread_exit()
, set_exception()
и set_exception_at_thread_exit()
сериализуются. Успешное обращение к set_value()
происходит-раньше обращения к функции std::future::get()
или std::shared_future::get()
, которая извлекает сохраненное значение.
STD::PROMISE::SET_VALUE_AT_THREAD_EXIT
, ФУНКЦИЯ-ЧЛЕН
Сохраняет значение в асинхронном результате, ассоциированном с *this
, но не делает этот результат готовым раньше момента завершения потока.
Объявление
Читать дальше