std::promise和std::future用于线程间异步通信,promise设置值或异常,future获取结果;示例中主线程通过future等待子线程计算结果,支持异常传递与超时检测,相比std::async更灵活,适用于手动控制任务完成场景。

在C++中,std::future 和 std::promise 是实现异步任务间通信的重要工具。它们提供了一种机制,让一个线程可以产生结果,而另一个线程等待该结果,从而实现解耦和高效协作。
std::promise 与 std::future 的基本关系
std::promise 是一个“承诺”,表示未来会设置一个值或异常;std::future 则是获取这个“承诺”结果的句柄。两者通过共享状态关联:一个 promise 对应一个 future。
典型使用模式:
创建一对 promise-future 将 promise 交给生产者线程 将 future 交给消费者线程用于等待结果 生产者调用 promise.set_value() 或 set_exception() 消费者调用 future.get() 获取结果或抛出异常
基础用法示例
// 示例:主线程等待子线程计算结果#include #include iostream>#include void compute(std::promise p) { int result = 42; // 模拟耗时计算 p.set_value(result); // 设置结果}int main() { std::promise prom; std::future fut = prom.get_future(); // 获取关联的 future std::thread t(compute, std::move(prom)); std::cout
注意:promise 必须通过 move 传递给线程,不能复制。每个 promise 只能 set_value() 一次,多次调用会导致程序终止。
立即学习“C++免费学习笔记(深入)”;
与 std::async 的对比
std::async 是更高层的异步接口,自动返回一个 future,适合直接启动可调用对象:
auto fut = std::async([]{ return 84; });int res = fut.get(); // 等待并获取结果
而 promise 更灵活,适用于:
需要手动控制结果设置时机 跨多个函数或事件传递结果(如回调、中断处理) 封装非标准异步操作(如网络IO完成通知)
异常传递与状态管理
除了正常值,promise 还能传递异常:
void may_fail(std::promise p) { try { throw std::runtime_error(“计算失败”); } catch (…) { p.set_exception(std::current_exception()); }}
当 future 调用 get() 时,会重新抛出该异常。这使得错误处理可以在等待线程中集中进行。
future 还支持非阻塞检查:wait_for 和 wait_until 可以指定超时,返回状态如 ready、timeout 或 deferred。
基本上就这些。合理使用 promise 和 future 能有效简化多线程编程中的数据同步问题,尤其适合任务分解和响应式设计场景。
以上就是c++++中std::future和std::promise的用法_c++异步任务通信机制解析的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1482398.html
微信扫一扫
支付宝扫一扫