命名空间
变体
操作

std::shared_future<T>::wait

来自 cppreference.cn
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(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)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
Hazard 指针
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(在 C++20 中弃用)
(C++11)(在 C++20 中弃用)
内存顺序
(C++11)(在 C++26 中弃用)
原子操作的自由函数
原子标志的自由函数
 
 
void wait() const;
(自 C++11 起)

阻塞直到结果可用。 调用后 valid() == true

如果在调用此函数之前 valid() == false,则行为未定义。

目录

[编辑] 参数

(无)

[编辑] 返回值

(无)

[编辑] 异常

可能抛出实现定义的异常。

[编辑] 注释

鼓励实现检测在调用之前 valid() == false 的情况,并抛出带有 std::future_error 错误条件的 std::future_errc::no_state

从多个线程在同一个 std::shared_future 上调用 wait 是不安全的; 预期用途是对于每个在同一共享状态上等待的线程,都拥有 std::shared_future 的副本。

[编辑] 示例

#include <chrono>
#include <future>
#include <iostream>
#include <thread>
 
int fib(int n)
{
    if (n < 3)
        return 1;
    else
        return fib(n - 1) + fib(n - 2);
}
 
int main()
{
    std::shared_future<int> f1 = std::async(std::launch::async, []() { return fib(40); });
    std::shared_future<int> f2 = std::async(std::launch::async, []() { return fib(43); });
 
    std::cout << "waiting... " << std::flush;
    const auto start = std::chrono::system_clock::now();
 
    f1.wait();
    f2.wait();
 
    const auto diff = std::chrono::system_clock::now() - start;
    std::cout << std::chrono::duration<double>(diff).count() << " seconds\n";
 
    std::cout << "f1: " << f1.get() << '\n';
    std::cout << "f2: " << f2.get() << '\n';
}

可能的输出

waiting... 1.61803 seconds
f1: 102334155
f2: 433494437

[编辑] 参见

等待结果,如果在指定的超时持续时间内不可用则返回
(公共成员函数) [编辑]
等待结果,如果直到达到指定时间点仍不可用则返回
(公共成员函数) [编辑]