std::promise<R>:: set_exception_at_thread_exit
From cppreference.net
C++
Concurrency support library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::promise
| Member functions | ||||
| Getting the result | ||||
| Setting the result | ||||
|
promise::set_exception_at_thread_exit
|
||||
| Non-member Functions | ||||
| Helper Classes | ||||
|
void
set_exception_at_thread_exit
(
std::
exception_ptr
p
)
;
|
(自 C++11 起) | |
将异常指针 p 存储到共享状态中,但不会立即使状态就绪。该状态将在当前线程退出时、所有具有线程局部存储期的变量都被销毁之后变为就绪状态。
该操作的行为表现为:当更新promise对象时,
set_value
、
set_exception
、
set_value_at_thread_exit
和
set_exception_at_thread_exit
会获取与promise对象关联的单个互斥锁。
如果没有共享状态或共享状态已存储值或异常,则抛出异常。
调用此函数不会与对 get_future 的调用产生数据竞争(因此它们无需彼此同步)。
目录 |
参数
| p | - | 用于存储的异常指针。若 p 为 nullptr 则行为未定义 |
返回值
(无)
异常
std::future_error 在以下情况下发生:
- * this 没有共享状态。错误码被设置为 no_state 。
- 共享状态已存储值或异常。错误码被设置为 promise_already_satisfied 。
示例
|
本节内容不完整
原因:缺少示例 |
参阅
|
将结果设置为指示异常
(公开成员函数) |