0

0

c++ TBB库怎么用 c++ Intel TBB并行编程【教程】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-02 17:21:31

|

551人浏览过

|

来源于php中文网

原创

Intel TBB是开源C++并行库,基于任务式并行抽象线程管理;提供parallel_for、parallel_reduce、并发容器及task_group等核心功能,并强调粒度适配与避免写竞争。

c++ tbb库怎么用 c++ intel tbb并行编程【教程】

Intel TBB(Threading Building Blocks)是一个开源的C++并行编程库,帮你轻松写出高效、可扩展的多线程代码,不用直接操作线程、锁或条件变量。核心思想是“任务式并行”——你描述“做什么”,TBB负责“怎么调度执行”。

1. 安装与基本配置

TBB已集成在Intel oneAPI中,也可单独下载源码编译。Linux/macOS常用方式:

  • Ubuntu/Debian:sudo apt install libtbb-dev
  • macOS(Homebrew):brew install tbb
  • 手动编译:从GitHub官方仓库拉取,mkdir build && cd build && cmake .. && make -j

编译时加链接选项:g++ -std=c++17 main.cpp -ltbb(Linux/macOS),Windows用MSVC需链接tbb.lib并包含头文件路径。

2. 核心并行算法:parallel_for 和 parallel_reduce

这是最常用、最直观的两个接口,替代传统for循环和累加逻辑。

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

魔术橡皮擦
魔术橡皮擦

智能擦除、填补背景内容

下载
  • parallel_for:对区间做并行遍历
    示例:并行计算数组平方
    tbb::parallel_for(tbb::blocked_range(0, n),
    [&](const tbb::blocked_range& r) {
    for (size_t i = r.begin(); i != r.end(); ++i)
    result[i] = data[i] * data[i];
    });
  • parallel_reduce:并行归约(如求和、最大值)
    示例:并行求vector元素和
    double sum = tbb::parallel_reduce(
    tbb::blocked_range(0, v.size()), 0.0,
    [&](const tbb::blocked_range& r, double init) -> double {
    for (size_t i = r.begin(); i != r.end(); ++i) init += v[i];
    return init;
    },
    [](double a, double b) { return a + b; }
    );

3. 任务调度与并发容器

TBB提供线程安全、高性能的并发数据结构,适合多线程协作场景:

  • tbb::concurrent_vector:支持多线程push_back,迭代器不保证稳定,但插入安全
  • tbb::concurrent_queue:生产者-消费者模型首选,无锁设计
  • tbb::task_group:手动管理异步任务依赖关系
    示例:启动两个独立任务并等待完成
    tbb::task_group g;
    g.run([]{ do_work_a(); });
    g.run([]{ do_work_b(); });
    g.wait(); // 阻塞直到全部结束

4. 注意事项与常见误区

TBB不是万能加速器,用错反而拖慢性能:

  • 粒度要合适:单个任务太小(如每次只处理1个int)会因调度开销抵消收益;建议每个子任务耗时 ≥ 数微秒
  • 避免共享写竞争:parallel_for里别让多个线程同时写同一内存位置,除非用原子操作或局部累积+reduce
  • 不要在parallel_for lambda里throw异常(TBB默认不传播异常),如需错误处理,改用tbb::parallel_for_exception_safe或自行封装
  • 调试时可临时禁用并行:tbb::global_control ctrl(tbb::global_control::max_allowed_parallelism, 1);

掌握这几个关键点,就能写出简洁又高效的并行C++代码。TBB抽象了线程管理细节,让你聚焦问题本身,而不是同步原语。

相关专题

更多
c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

520

2023.09.20

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

522

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

190

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

95

2025.10.23

lambda表达式
lambda表达式

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

202

2023.09.15

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

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

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