future(std::experimental::future<T>&& f) noexcept;
future(const std::experimental::future<T>&) = delete;
1) Default constructor. Constructs an empty
futureobject that does not refer to a shared state.
2) Constructs a
futureobject, transferring the shared state held by
f, if any. After construction, f.valid() is false.
3) Copy constructor is deleted.
futurecannot be copied.
4) Unwrapping constructor. Constructs a
futureobject from the shared state referred to by
other, if any. If
other.valid() == falseprior to this call, the constructed
futureobject is empty. Otherwise, the resulting
futureobject becomes ready when one of the following happens:
- other and other.get() are both ready. The value or exception from other.get() is stored in the shared state associated with the resulting
- other is ready, but other.get() is invalid. An exception of type std::future_error with an error condition of std::future_errc::broken_promise is stored in the shared state associated with the resulting
After this constructor returns, valid() is equal to the value of other.valid() prior to this call, and other.valid() == false.
|f||-||another future object to initialize with|
|other||-|| A |
|This section is incomplete|
Reason: no example
 Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
|DR||Applied to||Behavior as published||Correct behavior|
|LWG 2697||Concurrency TS|| behavior of unwrapping constructor is unclear with an invalid
|| constructs an empty |
 See also
| constructs the future object |
(public member function of