std::future和std::promise是C++11提供的单次异步值传递机制:promise设值/异常,future阻塞获取;需配对使用,仅能调用一次get()和set_*,支持超时等待与异常传播。
std::future 和 std::promise 是 C++11 引入的用于线程间传递单次值的配套机制,核心用途是实现异步任务的结果获取与主动设置。它们不直接管理线程,而是提供一种“结果通道”:一个线程通过 std::promise 设置结果,另一个线程通过关联的 std::future 等待并获取该结果。
std::promise 和 std::future 必须成对出现,通过 get_future() 建立绑定。promise 负责写入(set_value、set_exception),future 负责读取(get() 会阻塞直到有值)。
常见写法:
std::promise p; ,再调用 auto f = p.get_future();
p.set_value(42);(或 p.set_exception(...))f.get(); —— 若尚未设置,会阻
塞;设置后立即返回值(且只能调用一次)不同于 std::async 自动封装,用 promise + thread 可更灵活地控制执行时机和上下文。
示例场景:启动一个后台计算,完成后通知主线程
std::promise calc_promise; 和 auto result_fut = calc_promise.get_future();
calc_promise 按值或移动传入(注意线程安全:promise 不可拷贝,需 move 或引用传递)promise.set_value(x);
result_fut.get(); 获取结果(自动等待、自动释放资源)future 不仅能传值,还能传异常,使错误处理自然融入异步流:
p.set_exception(std::current_exception());
f.get() 时,该异常会被重新抛出f.wait_for(std::chrono::seconds(3)) 判断是否就绪,或 f.wait_until(...)
f.valid() 可检查 future 是否关联有效 promise(防止多次 get 或空 future)如果目标是“把一个可调用对象包装成带 future 的异步任务”,std::packaged_task 是更直接的选择——它内部已绑定 promise/future,省去手动配对。
std::packaged_task task([](int a, int b) { return a + b; });
auto fut = task.get_future();
task(3, 4); → 此时 future 就绪fut.get(); 得到 7不复杂但容易忽略:promise 和 future 是一次性使用的,get() 后 future 失效;promise 只能 set 一次,重复调用 set_* 会抛出 std::future_error。合理搭配 move 语义和 RAII,就能写出清晰可控的异步通信逻辑。