void operator()( ArgTypes... args ); | (since C++11) |
Calls the stored task as if by INVOKE<R>(f, args...)
, where f
is the stored task. The return value of the task or any exceptions thrown are stored in the shared state. The shared state is made ready and any threads waiting for this are unblocked.
args | - | the parameters to pass on invocation of the stored task |
(none).
std::future_error
on the following error conditions:
promise_already_satisfied
. *this
has no shared state. The error category is set to no_state
. The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 2142 | C++11 | a successful call to operator() synchronized with a call to any member function of a std::future orstd::shared_future that share their shared state with *this | no additional synchronization guarantees other than what is already provided by shared state |
executes the function ensuring that the result is ready only once the current thread exits (public member function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/thread/packaged_task/operator()