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

在C++11中,实现异步操作变得更为简单和安全,主要得益于std::future和std::async的引入。它们位于<future>头文件中,能够帮助开发者轻松地启动异步任务并获取其结果,而无需手动管理线程生命周期。
std::async是一个函数模板,用于异步地执行一个可调用对象(如函数、lambda表达式等),并返回一个std::future对象,用来获取异步操作的结果。
基本用法如下:
#include <future>
#include <iostream>
<p>int compute() {
// 模拟耗时计算
std::this_thread::sleep_for(std::chrono::seconds(2));
return 42;
}</p><p>int main() {
// 启动异步任务
std::future<int> result = std::async(compute);</p><pre class='brush:php;toolbar:false;'>// 做其他事情...
std::cout << "Doing other work...\n";
// 获取结果(会阻塞直到完成)
int value = result.get();
std::cout << "Result: " << value << "\n";
return 0;}
立即学习“C++免费学习笔记(深入)”;
std::async默认以“自动启动策略”运行任务,也可以显式指定启动方式:
get()或wait()时才在当前线程执行例如:
auto result = std::async(std::launch::async, compute); // 确保异步运行
std::future是异步操作的“承诺”,代表将来可用的结果。它提供几个关键方法:
使用超时示例:
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";
}
除了普通函数,std::async也支持lambda表达式,便于编写内联逻辑:
auto future = std::async([]() {
return 8 * 8;
});
<p>std::cout << "Lambda result: " << future.get() << "\n"; // 输出 64</p>如果异步任务抛出异常,该异常会被捕获并存储,当调用get()时重新抛出:
auto f = std::async([]() {
throw std::runtime_error("Something went wrong");
});
<p>try {
f.get();
} catch (const std::exception& e) {
std::cout << "Caught exception: " << e.what() << "\n";
}</p>基本上就这些。通过std::async和std::future,C++11提供了简洁高效的异步编程模型,适合大多数不需要精细控制线程的场景。虽然不如更现代的协程或回调机制灵活,但在中小型项目中非常实用。
以上就是C++如何实现异步操作_C++11使用std::future和std::async进行异步编程的详细内容,更多请关注php中文网其它相关文章!
编程怎么学习?编程怎么入门?编程在哪学?编程怎么学才快?不用担心,这里为大家提供了编程速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号