future wait_for()成员、shared_future

future wait_for()成员

wait_for():等待其异步操作操作完成或者超出等待,用于检查异步操作的状态。wait_for()可以接受一个std::chrono::duration类型的参数,它表示等待的最大时间,会返回一个std::future_status枚举值(枚举类型)。在最大时间范围内,wait_for()会尝试等待异步操作完成。如果wait_for()执行前或者wait_for()等待最大时间内异步任务完成,函数就会返回std::future_status::ready。如果wait_for()等待时间超过最大时间,函数就会返回std::future_status::timeout,表示等待超时。如果在调用async时使用了std::launch::deferred参数,那么函数将在future调用get()时在主线程中执行,而调用wait_for()会返回std::future_status::deferred,表示线程被延迟执行了。

#include<iostream>
#include<thread>
#include<future>
using namespace std;
int mythread(int i)
{
    std::chrono::milliseconds dura(5000);//
    std::this_thread::sleep_for(dura);//休息5秒
    return i;
}
int main()
{
    future<int> myfu = async<int(int)>(mythread, 5);
    std::future_status status = myfu.wait_for(std::chrono::seconds (6));//等待最长6秒
    if (status == std::future_status::ready)
    {
        cout << "我准备好了" << endl;
    }
    else if (status == std::future_status::ready)
    {
        cout << "超时了" << endl;
    }
    else if (status == std::future_status::deferred)
    {
        cout << "延迟执行了" << endl;
    }
    cout << myfu.get() << endl;

}

shared_future

std::shared_future 是 C++ 标准库中的一个模板类,它类似于 std::future,但允许多个线程或对象共享对异步操作结果的访问。std::shared_future 对象通常与 std::promise、std::packaged_task 对象一起使用,用于在多线程环境中安全地共享异步操作的。将返回的future对象移动到shared_future中,这样就可以对其中的数据进行多次的访问和复制了。可以使用valid()成员函数判断future对象是否执行了移动语义,它将返回一个bool值,如果future中有有效值就会返回true,没有返回false。shared_future对象可以多次调用get()函数对数据进行访问。同时future有专门的shared()成员函数,可以返回shared_future对象,用于对shared_future赋值。

#include<iostream>
#include<thread>
#include<future>
using namespace std;
int mythread(int i)
{
    return i;
}
int main()
{
    packaged_task<int(int)> pack(mythread);
    thread tl(std::ref(pack),5);
    tl.join();
    future<int> myfu = pack.get_future();
    shared_future<int> result = myfu.share();
    cout << result.get() << endl;
   

}