std::future和std::promise用于C++多线程间异步通信,实现生产者-消费者模式;std::promise设值或异常,std::future获取结果,二者通过get_future关联,支持异常传递与移动语义,需注意仅能设置一次且避免未设值销毁。

在C++多线程编程中,std::future 和 std::promise 是一对用于实现异步通信的重要工具。它们配合使用可以在线程之间传递结果或异常,实现一种“生产者-消费者”模式的数据传递机制。
std::promise 是一个可写入一次的容器,用于保存某个值或异常;而 std::future 是与之关联的只读对象,用于在未来某个时间点获取这个值。每个 promise 都可以通过 get_future() 获取对应的 future。
典型场景是一个线程计算结果并将其设置到 promise 中,另一个线程通过对应的 future 等待并获取该结果。
下面是一个简单的例子,展示两个线程如何通过 promise 和 future 进行通信:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include <thread>
#include <future>
void producer(std::promise<int>&& prms) {
try {
// 模拟耗时操作
std::this_thread::sleep_for(std::chrono::seconds(2));
int result = 42;
prms.set_value(result); // 设置结果
} catch (...) {
prms.set_exception(std::current_exception());
}
}
void consumer(std::future<int>&& fut) {
std::cout << "等待结果...\n";
int value = fut.get(); // 阻塞直到结果可用
std::cout << "收到结果:" << value << "\n";
}
int main() {
std::promise<int> prms;
std::future<int> fut = prms.get_future();
std::thread t1(producer, std::move(prms));
std::thread t2(consumer, std::move(fut));
t1.join();
t2.join();
return 0;
}
在这个例子中:
promise 不仅能传递正常值,还能传递异常。如果计算过程中发生错误,可以使用 set_exception() 方法将异常保存进去,future 在 get() 时会重新抛出该异常。
例如:
void faulty_producer(std::promise<double>&& prms) {
try {
throw std::runtime_error("计算失败");
} catch (...) {
prms.set_exception(std::current_exception());
}
}
当 consumer 调用 fut.get() 时,会抛出 runtime_error,需用 try-catch 处理。
使用 promise 和 future 时需要注意以下几点:
基本上就这些。合理使用 promise 和 future,可以让多线程任务的结果传递更清晰安全。虽然功能强大,但也注意避免死锁——比如不要在等待 future 的同时持有锁,导致生产者无法完成写入。
以上就是c++++中future和promise怎么配合使用_c++多线程异步通信实现的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号