Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/thread/future"

From cppreference.com
< cpp‎ | thread
m (Text replace - "{{mark c++11 feature}}" to "{{mark since c++11}}")
(Undo revision 170131 by Lynnboy (talk))
 
(38 intermediate revisions by 17 users not shown)
Line 1: Line 1:
 
{{cpp/title|future}}
 
{{cpp/title|future}}
{{cpp/thread/future/sidebar}}
+
{{cpp/thread/future/navbar}}
{{ddcl list begin}}
+
{{dcl begin}}
{{ddcl list header | future}}
+
{{dcl header|future}}
{{ddcl list item | num=1 | notes={{mark since c++11}} |
+
{{dcl|num=1|since=c++11|
 
template< class T > class future;
 
template< class T > class future;
 
}}
 
}}
{{ddcl list item | num=2 | notes={{mark since c++11}} |
+
{{dcl|num=2|since=c++11|
 
template< class T > class future<T&>;
 
template< class T > class future<T&>;
 
}}
 
}}
{{ddcl list item | num=3 | notes={{mark since c++11}} |
+
{{dcl|num=3|since=c++11|
template<>         class future<void>;
+
template<> class future<void>;
 
}}
 
}}
{{ddcl list end}}
+
{{dcl end}}
  
{{todo}}
+
The class template {{tt|std::future}} provides a mechanism to access the result of asynchronous operations:
 +
 
 +
* An asynchronous operation (created via {{lc|std::async}}, {{lc|std::packaged_task}}, or {{lc|std::promise}}) can provide a {{tt|std::future}} object to the creator of that asynchronous operation.
 +
 
 +
* The creator of the asynchronous operation can then use a variety of methods to query, wait for, or extract a value from the {{tt|std::future}}. These methods may block if the asynchronous operation has not yet provided a value.
 +
 
 +
* When the asynchronous operation is ready to send a result to the creator, it can do so by modifying ''shared state'' (e.g. {{lc|std::promise::set_value}}) that is linked to the creator's {{tt|std::future}}.
 +
 
 +
Note that {{tt|std::future}} references shared state that is not shared with any other asynchronous return objects (as opposed to {{lc|std::shared_future}}).
  
 
===Member functions===
 
===Member functions===
{{dcl list begin}}
+
{{dsc begin}}
{{dcl list mem ctor | cpp/thread/future/future | constructs the future object}}
+
{{dsc inc|cpp/thread/future/dsc constructor|future}}
{{dcl list mem dtor | cpp/thread/future/~future | destructs the future object}}
+
{{dsc inc|cpp/thread/future/dsc destructor}}
{{dcl list mem fun | cpp/thread/future/operator{{=}} | moves the future object}}
+
{{dsc inc|cpp/thread/future/dsc operator{{=}}}}
{{dcl list mem fun | cpp/thread/future/share | returns a {{rlpt|shared_future}} referring to the result associated to {{tt|*this}}}}
+
{{dsc inc|cpp/thread/future/dsc share}}
 +
 
 +
{{dsc h2|Getting the result}}
 +
{{dsc inc|cpp/thread/future/dsc get|future}}
 +
 
 +
{{dsc h2|State}}
 +
{{dsc inc|cpp/thread/future/dsc valid|future}}
 +
{{dsc inc|cpp/thread/future/dsc wait|future}}
 +
{{dsc inc|cpp/thread/future/dsc wait_for|future}}
 +
{{dsc inc|cpp/thread/future/dsc wait_until|future}}
 +
{{dsc end}}
 +
 
 +
===Examples===
 +
{{example
 +
|code=
 +
#include <future>
 +
#include <iostream>
 +
#include <thread>
 +
 
 +
int main()
 +
{
 +
    // future from a packaged_task
 +
    std::packaged_task<int()> task([]{ return 7; }); // wrap the function
 +
    std::future<int> f1 = task.get_future(); // get a future
 +
    std::thread t(std::move(task)); // launch on a thread
 +
 
 +
    // future from an async()
 +
    std::future<int> f2 = std::async(std::launch::async, []{ return 8; });
 +
 
 +
    // future from a promise
 +
    std::promise<int> p;
 +
    std::future<int> f3 = p.get_future();
 +
    std::thread([&p]{ p.set_value_at_thread_exit(9); }).detach();
 +
 
 +
    std::cout << "Waiting..." << std::flush;
 +
    f1.wait();
 +
    f2.wait();
 +
    f3.wait();
 +
    std::cout << "Done!\nResults are: "
 +
              << f1.get() << ' ' << f2.get() << ' ' << f3.get() << '\n';
 +
    t.join();
 +
}
 +
|output=
 +
Waiting...Done!
 +
Results are: 7 8 9
 +
}}
 +
 
 +
====Example with exceptions====
 +
{{example
 +
|code=
 +
#include <future>
 +
#include <iostream>
 +
#include <thread>
 +
 
 +
int main()
 +
{
 +
    std::promise<int> p;
 +
    std::future<int> f = p.get_future();
 +
 
 +
    std::thread t([&p]
 +
    {
 +
        try
 +
        {
 +
            // code that may throw
 +
            throw std::runtime_error("Example");
 +
        }
 +
        catch (...)
 +
        {
 +
            try
 +
            {
 +
                // store anything thrown in the promise
 +
                p.set_exception(std::current_exception());
 +
            }
 +
            catch (...) {} // set_exception() may throw too
 +
        }
 +
    });
 +
 
 +
    try
 +
    {
 +
        std::cout << f.get();
 +
    }
 +
    catch (const std::exception& e)
 +
    {
 +
        std::cout << "Exception from the thread: " << e.what() << '\n';
 +
    }
 +
    t.join();
 +
}
 +
|output=
 +
Exception from the thread: Example
 +
}}
  
{{dcl list h2 | Getting the result}}
+
===See also===
{{dcl list mem fun | cpp/thread/future/get | returns the result}}
+
{{dsc begin}}
 +
{{dsc inc|cpp/thread/dsc async}}
 +
{{dsc inc|cpp/thread/dsc shared_future}}
 +
{{dsc end}}
  
{{dcl list h2 | State}}
+
{{langlinks|de|es|fr|it|ja|pt|ru|zh}}
{{dcl list mem fun | cpp/thread/future/valid | checks if the result is available}}
+
{{dcl list mem fun | cpp/thread/future/wait | waits for the result to become available}}
+
{{dcl list mem fun | cpp/thread/future/wait_for | waits for the result, returns if it is not<br> available for the specified timeout duration}}
+
{{dcl list mem fun | cpp/thread/future/wait_until | waits for the result, returns if it is not<br> available until specified time point has been reached}}
+
{{dcl list end}}
+

Latest revision as of 05:11, 12 March 2024

 
 
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
(C++11)
Cooperative cancellation
Mutual exclusion
(C++11)
Generic lock management
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
future
(C++11)
(C++11)
(C++11)
Safe Reclamation
(C++26)
Hazard Pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11)(deprecated in C++20)
(C++11)(deprecated in C++20)
Memory ordering
Free functions for atomic operations
Free functions for atomic flags
 
 
Defined in header <future>
template< class T > class future;
(1) (since C++11)
template< class T > class future<T&>;
(2) (since C++11)
template<> class future<void>;
(3) (since C++11)

The class template std::future provides a mechanism to access the result of asynchronous operations:

  • The creator of the asynchronous operation can then use a variety of methods to query, wait for, or extract a value from the std::future. These methods may block if the asynchronous operation has not yet provided a value.
  • When the asynchronous operation is ready to send a result to the creator, it can do so by modifying shared state (e.g. std::promise::set_value) that is linked to the creator's std::future.

Note that std::future references shared state that is not shared with any other asynchronous return objects (as opposed to std::shared_future).

Contents

[edit] Member functions

constructs the future object
(public member function) [edit]
destructs the future object
(public member function) [edit]
moves the future object
(public member function) [edit]
transfers the shared state from *this to a shared_future and returns it
(public member function) [edit]
Getting the result
returns the result
(public member function) [edit]
State
checks if the future has a shared state
(public member function) [edit]
waits for the result to become available
(public member function) [edit]
waits for the result, returns if it is not available for the specified timeout duration
(public member function) [edit]
waits for the result, returns if it is not available until specified time point has been reached
(public member function) [edit]

[edit] Examples

#include <future>
#include <iostream>
#include <thread>
 
int main()
{
    // future from a packaged_task
    std::packaged_task<int()> task([]{ return 7; }); // wrap the function
    std::future<int> f1 = task.get_future(); // get a future
    std::thread t(std::move(task)); // launch on a thread
 
    // future from an async()
    std::future<int> f2 = std::async(std::launch::async, []{ return 8; });
 
    // future from a promise
    std::promise<int> p;
    std::future<int> f3 = p.get_future();
    std::thread([&p]{ p.set_value_at_thread_exit(9); }).detach();
 
    std::cout << "Waiting..." << std::flush;
    f1.wait();
    f2.wait();
    f3.wait();
    std::cout << "Done!\nResults are: "
              << f1.get() << ' ' << f2.get() << ' ' << f3.get() << '\n';
    t.join();
}

Output:

Waiting...Done!
Results are: 7 8 9

[edit] Example with exceptions

#include <future>
#include <iostream>
#include <thread>
 
int main()
{
    std::promise<int> p;
    std::future<int> f = p.get_future();
 
    std::thread t([&p]
    {
        try
        {
            // code that may throw
            throw std::runtime_error("Example");
        }
        catch (...)
        {
            try
            {
                // store anything thrown in the promise
                p.set_exception(std::current_exception());
            }
            catch (...) {} // set_exception() may throw too
        }
    });
 
    try
    {
        std::cout << f.get();
    }
    catch (const std::exception& e)
    {
        std::cout << "Exception from the thread: " << e.what() << '\n';
    }
    t.join();
}

Output:

Exception from the thread: Example

[edit] See also

(C++11)
runs a function asynchronously (potentially in a new thread) and returns a std::future that will hold the result
(function template) [edit]
waits for a value (possibly referenced by other futures) that is set asynchronously
(class template) [edit]