0

0

如何利用c++的std::async实现简单的并行for循环? (任务并行)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-18 08:59:02

|

835人浏览过

|

来源于php中文网

原创

不能。std::async仅启动异步任务并返回future,需手动分块、调用多个async、显式等待;标准库无开箱即用并行循环,c++17 std::for_each(std::execution::par)是更稳妥替代方案。

如何利用c++的std::async实现简单的并行for循环? (任务并行)

std::async 能不能直接替代 for 循环里的串行执行?

不能。std::async 不是并行循环的语法糖,它只负责启动一个异步任务并返回 std::future;你仍需手动拆分迭代范围、发起多个 std::async 调用,并显式等待全部完成。C++ 标准库至今没有提供类似 OpenMP 的 #pragma omp parallel for 或 Python 的 concurrent.futures 那样开箱即用的并行循环封装。

如何安全地把 for 循环拆成多个 async 任务?

关键在数据划分和生命周期管理。常见错误是捕获循环变量或容器引用导致悬垂指针或竞态——比如在 lambda 中按引用捕获 ivec,而主线程已退出作用域

  • 用值传递或显式拷贝需要的数据(如子区间起止索引、只读数据的 std::vector 副本)
  • 避免在 lambda 中捕获局部容器的引用;若必须访问原始容器,确保其生命周期覆盖所有 async 任务结束
  • 推荐按“块”(chunk)切分:例如将 0..N 分成 k 段,每段由一个 std::async 处理
  • 使用 std::launch::async 强制异步执行(默认策略可能延迟到 get() 时才同步运行)
std::vector<int> data = {/* ... large vector ... */};
const size_t N = data.size();
const size_t num_threads = std::thread::hardware_concurrency();
std::vector<std::future<void>> futures;
<p>for (size_t t = 0; t < num_threads; ++t) {
const size_t start = (N <em> t) / num_threads;
const size_t end   = (N </em> (t + 1)) / num_threads;
futures.emplace_back(std::async(std::launch::async, [start, end, &data]() {
for (size_t i = start; i < end; ++i) {
data[i] *= 2; // 示例:就地修改
}
}));
}</p><p>// 等待全部完成
for (auto& f : futures) f.wait();

为什么有时 async 比直接用 thread 还慢?

因为 std::async 默认启用延迟求值(std::launch::deferred)或线程池调度开销,且每个 std::future 析构时会隐式调用 wait() —— 若忘记显式 wait()get(),可能造成主线程阻塞在析构点,掩盖真实并发行为。

白月生产企业订单管理系统GBK2.0  Build 080807
白月生产企业订单管理系统GBK2.0 Build 080807

请注意以下说明:1、本程序允许任何人免费使用。2、本程序采用PHP+MYSQL架构编写。并且经过ZEND加密,所以运行环境需要有ZEND引擎支持。3、需要售后服务的,请与本作者联系,联系方式见下方。4、本程序还可以与您的网站想整合,可以实现用户在线服务功能,可以让客户管理自己的信息,可以查询自己的订单状况。以及返点信息等相关客户利益的信息。这个功能可提高客户的向心度。安装方法:1、解压本系统,放在

下载
  • 务必指定 std::launch::async,否则可能退化为同步执行
  • 大量细粒度任务(如每轮只处理 1 个元素)会让调度开销远超计算收益
  • 频繁创建/销毁 std::future 对象有额外分配成本;对超大循环,建议 chunk 大小至少几百次迭代
  • 注意异常传播:任一 async 抛异常,get()wait() 会重新抛出;未捕获则程序终止

有没有更稳妥的替代方案?

有。标准库虽无并行 for,但 C++17 起支持 std::for_each 的并行执行策略:std::execution::par。它由实现决定线程调度,语义清晰、无手动管理 future 的负担,且自动处理异常聚合:

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

std::vector<int> v = {/* ... */};
std::for_each(std::execution::par, v.begin(), v.end(), [](int& x) {
    x *= 2;
});

不过需确认编译器支持(GCC 9+、Clang 7+、MSVC 2019 16.2+),并链接对应线程库(如 -ltbb 或启用 libstdc++ 并行模式)。如果项目受限于旧标准或需精细控制线程数,std::async 手动分块仍是可行路径,但必须守住数据归属和 chunk 粒度这两条线。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

214

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

192

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

61

2026.01.05

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

97

2025.12.01

java值传递和引用传递有什么区别
java值传递和引用传递有什么区别

java值传递和引用传递的区别:1、基本数据类型的传递;2、对象的传递;3、修改引用指向的情况。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

109

2024.02.23

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

1

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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