std::future<T>:: get
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
| Getting the result | ||||
|
future::get
|
||||
| State | ||||
|
Основной шаблон
|
||
|
T get
(
)
;
|
(1) | (since C++11) |
|
std::
future
<
T
&
>
специализации
|
||
|
T
&
get
(
)
;
|
(2) | (since C++11) |
|
std::
future
<
void
>
специализация
|
||
|
void
get
(
)
;
|
(3) | (since C++11) |
Функция-член
get
ожидает (вызывая
wait()
) до тех пор, пока общее состояние не будет готово, после чего извлекает значение, хранящееся в общем состоянии (если оно есть). Сразу после вызова этой функции
valid()
возвращает
false
.
Если valid() возвращает false до вызова этой функции, поведение не определено.
Содержание |
Возвращаемое значение
Исключения
Если в общем состоянии, на которое ссылается future, было сохранено исключение (например, с помощью вызова std::promise::set_exception() ), то это исключение будет выброшено.
Примечания
Стандарт C++ рекомендует реализациям обнаруживать случай, когда valid() возвращает false до вызова и выбрасывать std::future_error с кодом ошибки std::future_errc::no_state .
Пример
#include <chrono> #include <future> #include <iostream> #include <string> #include <thread> std::string time() { static auto start = std::chrono::steady_clock::now(); std::chrono::duration<double> d = std::chrono::steady_clock::now() - start; return "[" + std::to_string(d.count()) + "s]"; } int main() { using namespace std::chrono_literals; { std::cout << time() << " launching thread\n"; std::future<int> f = std::async(std::launch::async, [] { std::this_thread::sleep_for(1s); return 7; }); std::cout << time() << " waiting for the future, f.valid() = " << f.valid() << '\n'; int n = f.get(); std::cout << time() << " f.get() returned " << n << ", f.valid() = " << f.valid() << '\n'; } { std::cout << time() << " launching thread\n"; std::future<int> f = std::async(std::launch::async, [] { std::this_thread::sleep_for(1s); return true ? throw std::runtime_error("7") : 7; }); std::cout << time() << " waiting for the future, f.valid() = " << f.valid() << '\n'; try { int n = f.get(); std::cout << time() << " f.get() returned " << n << ", f.valid() = " << f.valid() << '\n'; } catch (const std::exception& e) { std::cout << time() << " caught exception " << e.what() << ", f.valid() = " << f.valid() << '\n'; } } }
Возможный вывод:
[0.000004s] launching thread [0.000461s] waiting for the future, f.valid() = 1 [1.001156s] f.get() returned with 7, f.valid() = 0 [1.001192s] launching thread [1.001275s] waiting for the future, f.valid() = 1 [2.002356s] caught exception 7, f.valid() = 0
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 2096 | C++11 |
перегрузка
(1)
требовала проверки, является ли
T
MoveAssignable
|
не требуется |
Смотрите также
|
проверяет, содержит ли future общее состояние
(публичная функция-член) |