C++11通过std::async和std::future简化异步操作,支持自动或指定策略启动任务,利用future获取结果或处理异常,结合lambda表达式提升灵活性,适用于无需精细线程控制的场景。

在C++11中,实现异步操作变得更为简单和安全,主要得益于std::future和std::async的引入。它们位于头文件中,能够帮助开发者轻松地启动异步任务并获取其结果,而无需手动管理线程生命周期。
std::async 启动异步任务
std::async是一个函数模板,用于异步地执行一个可调用对象(如函数、lambda表达式等),并返回一个std::future对象,用来获取异步操作的结果。
基本用法如下:
#include #includeint compute() {// 模拟耗时计算std::this_thread::sleep_for(std::chrono::seconds(2));return 42;}
int main() {// 启动异步任务std::future result = std::async(compute);
// 做其他事情...std::cout << "Doing other work...n";// 获取结果(会阻塞直到完成)int value = result.get();std::cout << "Result: " << value << "n";return 0;
}
立即学习“C++免费学习笔记(深入)”;
std::async默认以“自动启动策略”运行任务,也可以显式指定启动方式:
std::launch::async:强制在新线程中立即执行std::launch::deferred:延迟执行,直到调用get()或wait()时才在当前线程执行
例如:
auto result = std::async(std::launch::async, compute); // 确保异步运行
std::future 获取异步结果
std::future是异步操作的“承诺”,代表将来可用的结果。它提供几个关键方法:
.get():获取结果,只能调用一次,之后future变为无效.wait():等待任务完成,不获取结果.wait_for() 或 .wait_until():设置超时等待
使用超时示例:
if (result.wait_for(std::chrono::milliseconds(100)) == std::future_status::ready) { std::cout << "Result is ready: " << result.get() << "n";} else { std::cout << "Task not ready yet.n";}
使用 Lambda 表达式进行异步操作
除了普通函数,std::async也支持lambda表达式,便于编写内联逻辑:
auto future = std::async([]() { return 8 * 8;});std::cout << "Lambda result: " << future.get() << "n"; // 输出 64
异常处理
如果异步任务抛出异常,该异常会被捕获并存储,当调用get()时重新抛出:
auto f = std::async([]() { throw std::runtime_error("Something went wrong");});try {f.get();} catch (const std::exception& e) {std::cout << "Caught exception: " << e.what() << "n";}
基本上就这些。通过std::async和std::future,C++11提供了简洁高效的异步编程模型,适合大多数不需要精细控制线程的场景。虽然不如更现代的协程或回调机制灵活,但在中小型项目中非常实用。
以上就是C++如何实现异步操作_C++11使用std::future和std::async进行异步编程的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1487228.html
微信扫一扫
支付宝扫一扫