cplusplus
.com
教程
参考
文章
论坛
C++
教程
参考
文章
论坛
参考
C 库
<cassert> (assert.h)
<cctype> (ctype.h)
<cerrno> (errno.h)
C++11
<cfenv> (fenv.h)
<cfloat> (float.h)
C++11
<cinttypes> (inttypes.h)
<ciso646> (iso646.h)
<climits> (limits.h)
<clocale> (locale.h)
<cmath> (math.h)
<csetjmp> (setjmp.h)
<csignal> (signal.h)
<cstdarg> (stdarg.h)
C++11
<cstdbool> (stdbool.h)
<cstddef> (stddef.h)
C++11
<cstdint> (stdint.h)
<cstdio> (stdio.h)
<cstdlib> (stdlib.h)
<cstring> (string.h)
C++11
<ctgmath> (tgmath.h)
<ctime> (time.h)
C++11
<cuchar> (uchar.h)
<cwchar> (wchar.h)
<cwctype> (wctype.h)
容器
C++11
<array>
<deque>
C++11
<forward_list>
<list>
<map>
<queue>
<set>
<stack>
C++11
<unordered_map>
C++11
<unordered_set>
<vector>
输入/输出
<fstream>
<iomanip>
<ios>
<iosfwd>
<iostream>
<istream>
<ostream>
<sstream>
<streambuf>
多线程
C++11
<atomic>
C++11
<condition_variable>
C++11
<future>
C++11
<mutex>
C++11
<thread>
其他
<algorithm>
<bitset>
C++11
<chrono>
C++11
<codecvt>
<complex>
<exception>
<functional>
C++11
<initializer_list>
<iterator>
<limits>
<locale>
<memory>
<new>
<numeric>
C++11
<random>
C++11
<ratio>
C++11
<regex>
<stdexcept>
<string>
C++11
<system_error>
C++11
<tuple>
C++11
<type_traits>
C++11
<typeindex>
<typeinfo>
<utility>
<valarray>
<future>
类
C++11
future
C++11
future_error
C++11
packaged_task
C++11
promise
C++11
shared_future
枚举类
C++11
future_errc
C++11
future_status
C++11
launch
函数
C++11
async
C++11
future_category
promise
C++11
promise::~promise
C++11
promise::promise
成员函数
C++11
promise::get_future
C++11
promise::operator=
C++11
promise::set_exception
C++11
promise::set_exception_at_thread_exit
C++11
promise::set_value
C++11
promise::set_value_at_thread_exit
C++11
promise::swap
非成员重载
C++11
swap (promise)
非成员特化
C++11
uses_allocator<promise>
参考
<future>
promise
set_exception_at_thread_exit
public member function
<future>
std::
promise
::set_exception_at_thread_exit
void set_exception_at_thread_exit (exception_ptr p);
Set exception at thread exit
将异常指针
p
存储在
共享状态
中,但不立即使其
就绪
。相反,它将在线程退出时,在所有
线程存储期
对象销毁后自动使其
就绪
。
如果与同一
共享状态
关联的
future
对象正在等待
future::get
调用,它将保持阻塞直到线程结束。线程结束时,它将抛出由
p
指向的异常对象。
请注意,调用此函数已经为
共享状态
设置了值,如果在本次调用与线程结束之间修改该值的任何调用都会抛出具有
promise_already_satisfied
作为
错误条件
的
future_error
。
参数
p
一个
exception_ptr
对象。
exception_ptr
是一种用于引用异常对象的智能指针类型。
返回值
无
数据竞争
promise
对象被修改。
共享状态
被修改为
原子操作
(不会导致数据竞争)。
异常安全
基本保证:
如果抛出异常,则
promise
对象处于有效状态。
此成员函数在以下条件下抛出异常
exception type
error condition
描述
future_error
future_errc::no_state
该对象没有
共享状态
(它已被
移动赋值
)
future_error
future_errc::promise_already_satisfied
共享状态
已存储值或异常
根据库实现的不同,此成员函数还可能抛出异常来报告其他情况。
另见
promise::set_exception
Set exception
(public member function)
promise::set_value_at_thread_exit
Set value at thread exit
(public member function)
future::get
Get value
(public member function)