C++多线程学习10 promise和future多线程异步传值

进程的执行具有间断性,进程按格子独立的、不可预知的速度向前推进。什么时候获得线程中的某个结果是不确定的。
想要获得线程的确定的计算结果,使用之前的锁的策略也能实现,但比较麻烦,因此有必要使用更简洁的promise 和 future

假设线程1需要线程2的数据,那么组合使用方式如下:

线程1初始化一个promise对象和一个future对象,promise传递给线程2,相当于线程2对线程1的一个承诺;future相当于一个接受一个承诺,用来获取未来线程2传递的值
线程2获取到promise后,需要对这个promise传递有关的数据,之后线程1的future就可以获取数据了。
如果线程1想要获取数据,而线程2未给出数据,则线程1阻塞,直到线程2的数据到达
一个简单的说明流程:
在这里插入图片描述
来源:图解future和promise

future_status有三种状态:
(1)deferred:异步操作还没开始
(2)ready:异步操作已经完成
(3)timeout:异步操作超时

future提供了一些函数比如get(),wait(),wait_for():
(1)get()来获取future所得到的结果,如果异步操作还没有结束,那么会在此等待set_value()设置共享状态的值,此后 promise 的共享状态标志变为 ready,并获取返回的结果。
(2)wait()只是在此等待异步操作的结束,并不能获得返回结果。
(3)wait_for()超时等待返回结果。
参考:https://zhuanlan.zhihu.com/p/448035015

要引入future库

#include <thread>
#include <iostream>
#include <future>
#include <string>
using namespace std;

void TestFuture(promise<string> p)
{
    cout << "begin TestFuture" << endl;
    this_thread::sleep_for(3s);
    cout << "begin set value" << endl;
    p.set_value("TestFuture value");
    this_thread::sleep_for(3s);
    cout << "end TestFuture" << endl;
}

int main(int argc, char* argv[])
{
    //异步传输变量存储
    promise<string> p;
    //用来获取线程异步值获取
    auto future = p.get_future();
    auto th = thread(TestFuture, move(p));
 
        cout << "future get() = " << future.get() << endl;

    th.join();
    getchar();
    return 0;
}

先创建一个测试线程对主线程的承诺p,再从p中获得future对象,用这个对象做为信物来接收承诺P产生的值,在创建线程的时候将这个承诺传过去,然后主线程想要获得信物的值,在测试线程对承诺设置值之前主线程将在get那等待,设置好值后将返回这个值:
在这里插入图片描述
注意,使用promise机制来创建线程的时候promise类型为std::promisestd::string&&,即右值引用,所以要用move()让P这里能当做右值使用,才能与右值引用匹配:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
futurepromiseC++标准库中用于在线程间传递数据的方式之一。std::future作为数据的输出端,用于获取异步操作的结果。而std::promise则作为数据的输入端,用于设置异步操作的结果。 通过std::promise可以设置一个值,而通过std::future可以获取这个值。 在C++标准库中,有两种类型的期望,分别是唯一期望(unique futures)和共享期望(shared futures)。std::future是唯一期望的实例,它只能与一个指定事件相关联。而std::shared_future是共享期望的实例,它可以关联多个事件。 可以使用std::promise和std::future来进行线程间的数据传递。例如,可以使用std::promise来设置一个值,然后通过std::future来获取这个值。示例代码如下: ```C++ std::promise<int> promise; std::future<int> future = promise.get_future(); std::thread producer([&promise(){ // 在子线程中设置值 promise.set_value(42); }); // 在主线程中获取值 int value = future.get(); producer.join(); ``` 在这个例子中,我们创建了一个std::promise对象和一个std::future对象,然后将std::future对象与std::promise对象关联起来。在子线程中,通过调用promise.set_value()方法来设置值为42。在主线程中,通过调用future.get()方法来获取值。最后,我们调用join()方法等待子线程的结束。 另外,可以使用std::shared_future来实现多次访问共享的future对象。示例代码如下: ```C++ std::future<int> fut = std::async([](){return 10;}); std::shared_future<int> shared_fut = fut.share(); std::cout << "value: " << shared_fut.get() << '\n'; std::cout << "its double: " << shared_fut.get() * 2 << '\n'; ``` 在这个例子中,我们创建了一个std::future对象fut,并通过std::async()函数异步执行一个任务,返回值为10。然后,我们使用fut.share()方法创建了一个共享的std::shared_future对象shared_fut。通过调用shared_fut.get()方法多次访问这个共享的future对象。 综上所述,futurepromiseC++标准库中用于在线程间传递数据的方式之一,通过std::future可以获取异步操作的结果,而通过std::promise可以设置异步操作的结果。可以使用std::shared_future实现多次访问共享的future对象。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值