Пространства имён
Варианты
Действия

std::future

Материал из cppreference.com
< cpp‎ | thread
 
 
Библиотека поддержки конкуренции
Ветви
(C++11)
(C++20)
(C++20)
Пространство имён this_thread
(C++11)
(C++11)
(C++11)
Атомарные типы
(C++11)
(C++20)
Инициализация атомарных типов
(C++11)(устарело в C++20)
(C++11)(устарело в C++20)
(C++11)(устарело в C++20)
Функции освобождения для атомарных операций
Функции освобождения для атомарных флагов
Упорядочивание памяти
Взаимное исключение
(C++11)
Общее управление блокировкой
(C++11)
(C++11)
(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
Условные переменные
(C++11)
Семафоры
Защёлки и барьеры
(C++20)
(C++20)
Фьючерсы
(C++11)
future
(C++11)
(C++11)
(C++11)
 
std::future
Функции-элементы
Получение результата
Состояние
 
Определено в заголовочном файле <future>
template< class T > class future;
(1) (начиная с C++11)
template< class T > class future<T&>;
(2) (начиная с C++11)
template<>          class future<void>;
(3) (начиная с C++11)

Шаблонный класс std::future обеспечивает механизм доступа к результатам асинхронных операций:

  • Асинхронные операции (созданные с помощью std::async, std::packaged_task или std::promise) могут вернуть объект типа std::future создателю этой операции.
  • Создатель асинхронной операции может использовать различные методы для запроса, ожидания или получения значения из std::future. Эти методы могут заблокировать выполнение до получения результата асинхронной операции.
  • Когда асинхронная операция готова к отправке результата её создателю, она может сделать это, изменив общее состояние (например, std::promise::set_value), которое связано с std::future создателя.

Обратите внимание, что std::future ссылается на общее состояние, которое не используется никакими другими асинхронными возвращаемыми объектами (в отличие от std::shared_future).

Содержание

[править] Функции-элементы

создаёт объект future
(public функция-элемент) [править]
разрушает объект future
(public функция-элемент) [править]
перемещает объект future
(public функция-элемент) [править]
передаёт общее состояние из *this в shared_future и возвращает его
(public функция-элемент) [править]
Получение результата
возвращает результат
(public функция-элемент) [править]
Состояние
проверяет, имеет ли future общее состояние
(public функция-элемент) [править]
ждёт, пока результат станет доступным
(public функция-элемент) [править]
ждёт результата, возвращается, если он недоступен в течение указанного времени ожидания
(public функция-элемент) [править]
ждёт результата, возвращается, если он недоступен, пока не будет достигнут указанный момент времени
(public функция-элемент) [править]

[править] Пример

#include <iostream>
#include <future>
#include <thread>
 
int main()
{
    // future из packaged_task
    std::packaged_task<int()> task([]{ return 7; }); // оборачивает функцию
    std::future<int> f1 = task.get_future();  // получает future
    std::thread t(std::move(task)); // запускает в потоке
 
    // future из async()
    std::future<int> f2 = std::async(std::launch::async, []{ return 8; });
 
    // future из 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 << "Ожидание..." << std::flush;
    f1.wait();
    f2.wait();
    f3.wait();
    std::cout << "Готово!\nРезультаты: "
              << f1.get() << ' ' << f2.get() << ' ' << f3.get() << '\n';
    t.join();
}

Вывод:

Ожидание...Готово!
Результаты: 7 8 9

[править] Пример с исключениями

#include <thread>
#include <iostream>
#include <future>
 
int main()
{
    std::promise<int> p;
    std::future<int> f = p.get_future();
 
    std::thread t([&p]{
        try {
            // код, который может бросить исключение
            throw std::runtime_error("Пример");
        } catch(...) {
            try {
                // хранить всё, что брошено в promise
                p.set_exception(std::current_exception());
            } catch(...) {} // set_exception() тоже может бросить исключение
        }
    });
 
    try {
        std::cout << f.get();
    } catch(const std::exception& e) {
        std::cout << "Исключение из потока: " << e.what() << '\n';
    }
    t.join();
}

Вывод:

Исключение из потока: Пример

[править] Смотрите также

(C++11)
выполняет функцию асинхронно (возможно, в новом потоке) и возвращает std::future, который будет содержать результат
(шаблон функции) [править]
ожидает значение (возможно, на которое ссылаются другие разделяемые состояния), которое устанавливается асинхронно
(шаблон класса) [править]