C++11之std::promise使用介绍

本文详细介绍了C++11中的promise和future机制,包括它们的基本概念、使用方式及示例代码。promise与future是C++11并发编程的重要组成部分,用于线程间的异步通信。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在C++11中有个future头文件,在这个头文件有一个promise类模板,std::promise 提供存储值或异常的设施,之后通过 std::promise 对象所创建的 std::future 对象异步获得结果。其模板声明如下:

template< class R > 
class promise;1) //空模板

template< class R > 
class promise<R&>;//非 void 特化,用于在线程间交流对象

template<>          
class promise<void>;//void 特化,用于交流无状态事件

每个 promise 与共享状态关联,共享状态含有一些状态信息和可能仍未求值的结果,非void特化类型的promise,其类型R就是线程间交流对象的类型;

promise/future一般是配对使用的,其中:

  • promise是 promise-future 交流通道的“推”端,它可以在某一时刻设置共享状态的值,通过promise的set系列函数进行设置。

  • future 对象可以异步返回共享状态的值,或者在必要的情况下阻塞调用者并等待共享状态标志变为 ready,然后才能获取共享状态的值。

示例

下面演示了通过promise/future对,进行线程间交流,一个线程用于设置共享状态,另一个线程用于获取共享状态结果,代码示例如下:

#include <iostream>           // std::cout
#include <thread>             // std::thread
#include <chrono>
#include <future>
#include <mutex>
using namespace std;

typedef struct 
{
   string   strName;
   string   strAdd;
   float    fResult;
}STRU_STUDENT_INFO;

std::mutex g_mut;


//get operate 
void get_val (std::promise<STRU_STUDENT_INFO>& promise) 
{
    this_thread::sleep_for(chrono::seconds(1));
  
    try 
    {
        //enter set_val thread;
        g_mut.lock();
        cout << "enter get thread: " << std::this_thread::get_id() << "\n";
        g_mut.unlock();
        
	    //通过futur对象来获取共享状态中的值
        future<STRU_STUDENT_INFO> fut = promise.get_future();
         
        //阻塞获取,只能get 一次
        STRU_STUDENT_INFO x = fut.get();
        
        std::cout << "You entered " << " name :"    << x.strName 
                                    << "\taddr:"    << x.strAdd 
                                    << "\tresult: " << x.fResult << '\n';
    }
    catch (...)
    {
        std::cout << "[exception caught]";
    }
}

//set operate
void set_val(std::promise<STRU_STUDENT_INFO>& pro)
{
    this_thread::sleep_for(chrono::seconds(1));
    
    STRU_STUDENT_INFO student;
    student.strName = "jinxiang";
    student.strAdd  = "fuzhou";
    student.fResult = 92.1;
    
    //enter set_val thread;
    g_mut.lock();
    cout << "enter set thread: " << std::this_thread::get_id() << "\n";
    g_mut.unlock();
        
    
    //设置共享状态值,实现线程间状态交流
    pro.set_value(student);  
}


int main(int argc, char *argv[])
{
    promise<STRU_STUDENT_INFO> promise;  
    
    //利用promise和future完成对线程间通信
    thread th1(get_val, ref(promise));
    thread th2(set_val, ref(promise));
     
    th1.join();
    th2.join();
    return 0;
}

运行结果:

enter get thread: 140354130814720
enter set thread: 140354122422016
You entered  name :jinxiang	addr:fuzhou	result: 92.1

promise不支持拷贝构造,只能进行移动操作,例如

promise<int> p1;
//ok
promise<int> p2 = std::move(p1);
//error
promise<int> p3 = p2;

总结

类模板promise通过promise/future对完成对共享状态的设置和获取,可用于线程间对象交流,对象的类型就是promise的模板参数。

参考资料:
http://www.cnblogs.com/haippy/p/3239248.html
http://zh.cppreference.com/w/cpp/thread/promise

### 回答1: 在C++中,std::promise是一种线程间通信机制,它允许一个线程在另一个线程中设置一个值。在使用std::promise时,一个线程可以将一个值传递给另一个线程,而无需等待该线程返回。具体而言,std::promise允许线程A创建一个std::future对象并将其返回给线程B,线程B可以在某个时间点通过调用std::promise的set_value()方法来设置std::future对象的值。一旦std::future对象被设置了值,线程A可以通过调用std::future对象的get()方法来获取该值。在使用std::promise时,需要注意的是,一个std::promise对象只能被设置一次值,因此在使用它时需要小心。 ### 回答2: std::promiseC++标准库中的一个类,用于在线程之间传递异步操作的结果。它通常与 std::future 一起使用,通过 std::promise 传递数据给 std::future 对象,在另一个线程中可以获取到该数据。 std::promise 的用法可以分为三个步骤:创建 promise 对象、获取 future 对象、设置 promise 对象的值。 首先,我们需要创建一个 promise 对象,这可以通过构造函数来完成,例如:std::promise<int> myPromise; 这样就创建了一个用于传递 int 类型数据的 promise 对象。 接下来,我们需要使用 promise 对象获取对应的 future 对象,通过调用 promise 对象的成员函数 std::promise::get_future() 来获取,例如:std::future<int> myFuture = myPromise.get_future(); 这样就获得了一个用于接收 int 类型数据的 future 对象。 最后,我们可以通过设置 promise 对象的值来传递数据给 future 对象。这可以通过调用 promise 对象的成员函数 std::promise::set_value() 来完成,例如:myPromise.set_value(42); 这样就将值 42 传递给了之前创建的 future 对象。 在另一个线程中,我们可以通过调用 future 对象的成员函数 std::future::get() 来获取到设置的值,例如:int result = myFuture.get(); 这样就可以获取到之前设置的值 42。 需要注意的是,一旦 promise 对象被设置了值,就不能再次设置。如果我们不希望在某些情况下传递数据到 future 对象,可以使用 std::promise::set_exception() 来设置一个异常。 总而言之,std::promise 提供了一种方便的机制来在线程之间传递异步操作的结果,通过设置 promise 对象的值,可以在另一个线程中获取到这些值,并进行相应的处理。 ### 回答3: std::promiseC++标准库中的一个类模板,用于多线程编程中用来存放一个值或者一个异常的容器。它通常与std::future一起使用,将一个值或异常从一个线程传递到另一个线程。 std::promise提供了两个主要的成员函数set_value()和set_exception()来设置值和异常。当一个线程调用set_value()或set_exception()时,std::promise的状态会变为“就绪”状态。其他线程可以通过std::future对象获取std::promise中的值或异常。 使用std::promise的基本步骤如下: 1. 创建一个std::promise对象,例如std::promise<int> p; 2. 创建一个std::future对象,通过std::promise的get_future()成员函数获取,例如std::future<int> f = p.get_future(); 3. 启动一个线程,该线程可以在某个时间点调用p.set_value()或p.set_exception()来设置值或异常。 4. 在需要的地方,通过std::future对象的get()成员函数获取std::promise中的值或异常。 例如,通过std::promise实现一个计算线程和一个读取结果的线程的示例: ``` #include <iostream> #include <thread> #include <functional> #include <future> void calculate(std::promise<int>& resultPromise, int a, int b) { int result = a + b; resultPromise.set_value(result); } int main() { std::promise<int> resultPromise; std::future<int> resultFuture = resultPromise.get_future(); std::thread calculationThread(calculate, std::ref(resultPromise), 3, 4); // 等待计算线程完成 calculationThread.join(); // 读取结果 int result = resultFuture.get(); std::cout << "Result: " << result << std::endl; return 0; } ``` 这个示例中,计算线程通过调用resultPromise.set_value()来设置结果值,读取结果的线程通过resultFuture.get()来阻塞等待结果值的返回,这样就实现了两个线程之间的值的传递和同步。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值