std::promise
|   Defined in header  
<future>
  | 
||
|   template< class T > class promise; 
 | 
(1) | (since C++11) | 
|   template< class T > class promise<T&>; 
 | 
(2) | (since C++11) | 
|   template<>          class promise<void>; 
 | 
(3) | (since C++11) | 
The class template std::promise provides a facility to store a value or an exception that is later acquired asynchronously via a std::future object created by the std::promise object.
Each promise is associated with a shared state, which contains some state information and a result which may be not yet evaluated, evaluated to a value (possibly void) or evaluated to an exception. A promise may do three things with the shared state:
- make ready: the promise stores the result or the exception in the shared state. marks the state ready and unblocks any thread waiting on a future associated with the shared state.
 - release: the promise gives up its reference to the shared state. If this was the last such reference, the shared state is destroyed. Unless this was a shared state created by std::async which is not yet ready, this operation does not block.
 - abandon: the promise stores the exception of type std::future_error with error code std::future_errc::broken_promise, makes the shared state ready, and then releases it.
 
The promise is the "push" end of the promise-future communication channel: the operation that stores a value in the shared state synchronizes-with (as defined in std::memory_order) the successful return from any function that is waiting on the shared state (such as std::future::get). Concurrent access to the same shared state may conflict otherwise: for example multiple callers of std::shared_future::get must either all be read-only or provide external synchronization.
Contents | 
[edit] Member functions
|   constructs the promise object  (public member function)  | 
|
|   destructs the promise object  (public member function)  | 
|
|    assigns the shared state  (public member function)  | 
|
|    swaps two promise objects  (public member function)  | 
|
 Getting the result | 
|
|    returns a future associated with the promised result  (public member function)  | 
|
 Setting the result | 
|
|    sets the result to specific value  (public member function)  | 
|
|    sets the result to specific value while delivering the notification only at thread exit  (public member function)  | 
|
|    sets the result to indicate an exception  (public member function)  | 
|
|    sets the result to indicate an exception while delivering the notification only at thread exit  (public member function)  | 
|
[edit] Non-member functions
|    (C++11) 
 | 
   specializes the std::swap algorithm  (function template)  | 
[edit] Helper classes
|    specializes the std::uses_allocator type trait   (class template specialization)  |