首页 > 后端开发 > C++ > 正文

c++如何使用std::async进行异步编程_c++异步任务与future用法说明

穿越時空
发布: 2025-11-17 03:37:36
原创
996人浏览过
std::async 提供异步任务执行,返回 future 获取结果,支持 launch 策略控制线程行为,结合 get/wait 实现同步与异常安全,适用于中小规模并发。

c++如何使用std::async进行异步编程_c++异步任务与future用法说明

在C++11中,std::async 提供了一种简单而强大的方式来执行异步任务。它能自动创建线程(或延迟执行),并返回一个 std::future 对象,用于获取异步操作的结果。这种方式避免了手动管理线程的复杂性,同时提供了良好的封装性和错误处理机制。

std::async 基本用法

std::async 是一个函数模板,用于启动一个异步任务。它可以接受一个可调用对象(函数、lambda、函数对象等)作为参数,并返回一个 std::future,通过该 future 可以在未来某个时间点获取结果。

基本语法如下:

std::future fut = std::async(launch_policy, callable, args...);

其中:

立即学习C++免费学习笔记(深入)”;

  • launch_policy:指定启动策略,可选 std::launch::async(强制异步执行,即创建新线程)或 std::launch::deferred(延迟执行,直到调用 get 或 wait);若不指定,则由系统自行决定。
  • callable:要异步执行的函数或 lambda 表达式。
  • args...:传递给 callable 的参数。

示例:

#include <iostream>
#include <future>
#include <thread>

int compute() {
std::this_thread::sleep_for(std::chrono::seconds(2));
return 42;
}

int main() {
auto fut = std::async(std::launch::async, compute);
std::cout << "异步任务已启动...\n";

int result = fut.get(); // 阻塞等待结果
std::cout << "结果: " << result << "\n";
return 0;
}

std::future 与结果获取

std::future 是一个模板类,代表一个将在未来某个时刻可用的值。它是异步操作结果的“占位符”。

常用方法包括:

豆包AI编程
豆包AI编程

豆包推出的AI编程助手

豆包AI编程 483
查看详情 豆包AI编程
  • .get():获取结果。一旦结果准备好就返回;否则阻塞当前线程直到结果就绪。注意:每个 future 的 get() 只能调用一次,多次调用会抛出异常。
  • .wait():等待异步操作完成,但不获取结果。
  • .valid():检查 future 是否持有合法的共享状态(未被 move 或已调用过 get)。

示例:使用 wait 和 get 分离等待与取值

auto fut = std::async([](){
std::this_thread::sleep_for(std::chrono::milliseconds(500));
return 100;
});

fut.wait(); // 等待完成
if (fut.valid()) {
std::cout << "结果是: " << fut.get() << "\n";
}

异常处理与安全性

异步任务中抛出的异常会被捕获并存储在 shared state 中。当调用 future::get() 时,异常会重新抛出,因此应使用 try-catch 包裹 get 调用。

示例:

auto bad_task = std::async([]{
throw std::runtime_error("出错了!");
});

try {
bad_task.get();
} catch (const std::exception& e) {
std::cout << "捕获异常: " << e.what() << "\n";
}

这样可以安全地处理异步任务中的错误,避免程序崩溃。

任务调度与性能考量

std::async 的实际行为依赖于 launch policy:

  • 使用 std::launch::async 强制开启新线程,适合必须并发执行的任务。
  • 使用 std::launch::deferred 则不会立即运行,而是延迟到调用 get 或 wait 时才在当前线程执行,适合可能不需要执行的情况。
  • 默认策略(不传 policy)由运行时决定,可能是 async 或 deferred,这可能导致不可预期的行为,特别是在大量使用 async 时可能耗尽线程资源。

建议:

  • 对计算密集型任务明确使用 std::launch::async
  • 避免无限制地创建 async 任务,考虑使用线程池或任务队列控制并发数量。
  • 注意 future 析构时若仍有关联的异步操作未完成,且为 deferred 策略,则会在析构时同步执行。

基本上就这些。std::async + future 提供了简洁的异步编程模型,适合中小规模的并发需求,理解其行为和限制有助于写出高效可靠的代码。

以上就是c++++如何使用std::async进行异步编程_c++异步任务与future用法说明的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号