std::promise和std::future用于线程间异步传递结果,promise设置值或异常,future获取结果,二者通过共享状态关联,支持阻塞获取和超时等待,适用于生产者-消费者模型。

在C++中,std::future 和 std::promise 是用于异步任务之间传递结果的核心工具。它们提供了一种机制:一个线程可以将计算结果“承诺”给另一个线程,而接收方可以通过“未来”对象来获取这个值,即使它尚未准备好。
std::promise 是一个可写入一次的对象,用来设置某个值或异常;std::future 是其对应的只读句柄,用来获取那个值。两者通过共享状态关联。
简单来说:
下面是一个简单的例子,展示如何用 promise 和 future 在两个线程间通信:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include <thread>
#include <future>
void producer(std::promise<int>&& prom) {
try {
// 模拟耗时操作
std::this_thread::sleep_for(std::chrono::seconds(2));
int result = 42;
prom.set_value(result); // 设置结果
} catch (...) {
prom.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> prom;
std::future<int> fut = prom.get_future();
std::thread t1(producer, std::move(prom));
std::thread t2(consumer, std::move(fut));
t1.join();
t2.join();
return 0;
}
输出:
等待结果... 收到结果:42
注意:promise 和 future 都只能移动,不能复制,因为每个共享状态只能有一个生产者和一个消费者。
除了 get() 这种阻塞方式,future 还支持带超时的等待:
示例:检查是否完成而不阻塞太久
std::future<int> fut = prom.get_future();
auto status = fut.wait_for(std::chrono::milliseconds(100));
if (status == std::future_status::ready) {
std::cout << "结果已就绪:" << fut.get() << "\n";
} else if (status == std::future_status::timeout) {
std::cout << "还在处理中,稍后再试\n";
}
std::async 是更高层的异步接口,会自动启动任务并返回一个 future。而 promise/future 更灵活,允许你手动控制何时设置结果。
适用场景对比:
promise 不仅能传递正常值,还能传递异常。这使得错误处理更安全:
try {
throw std::runtime_error("出错了!");
} catch (...) {
prom.set_exception(std::current_exception());
}
consumer 中调用 fut.get() 会重新抛出这个异常,可以被正常 catch。
以上就是c++++中std::future和std::promise的用法_c++异步任务通信机制详解的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号