std::shared_future用于多线程安全共享同一异步结果,解决std::future不可拷贝、独占使用的问题;可通过future::share()获得,支持多线程并发get()且线程安全。

std::shared_future 是 C++11 引入的、用于在多个线程间**安全共享同一个异步结果**的工具,它解决了 std::future 只能移动、不可复制的问题。
普通 std::future 是“独占型”的:一旦被 get() 或 wait(),就不能再被其他对象使用;而且它不可拷贝(只支持移动)。这在需要多个线程等待或读取同一异步结果时很不方便。
std::shared_future 允许你从一个 future 创建多个可拷贝的副本,每个副本都能独立调用 get()、wait()、valid() 等操作,且行为一致(比如都阻塞到结果就绪,都返回相同值)。
不能直接构造,必须通过以下方式获得:
立即学习“C++免费学习笔记(深入)”;
std::future::share() —— 把一个 future 转成 shared_future(原 future 失效)std::async、std::packaged_task 或 std::promise 获取的 future,立即调用 share()
示例:
auto f = std::async([]{ return 42; });
std::shared_future<int> sf = f.share(); // ✅ 正确
// auto f2 = f; // ❌ 编译失败:future 不可拷贝
auto sf2 = sf; // ✅ 可拷贝
当你有一个耗时计算(如网络请求、文件读取),而多个线程都需要这个结果时,shared_future 就是天然的“广播中心”:
future,立刻转为 shared_future
shared_future 拷贝给多个工作线程(例如通过 lambda 捕获或参数传递)sf.get()(首次调用会阻塞并获取值,后续调用直接返回缓存值)注意:shared_future::get() 是线程安全的,多个线程并发调用不会导致数据竞争。
如果你需要手动控制结果设置时机(比如多个子任务完成后才 set_value),可以用 std::promise:
promise<t></t>,调用 get_future().share() 得到 shared_future
shared_future 分发出去,把 promise 保留在能触发结果的地方promise.set_value(...) 或 set_exception(...)
这样就能实现“延迟广播”——结果不是由 async 自动产生,而是由你显式决定何时发出。
基本上就这些。shared_future 不复杂,但容易忽略它对多线程协作的价值:它让“一个源头、多方等待”这件事变得简洁又安全。
以上就是c++++中的std::shared_future是什么_c++广播异步结果【多线程】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号