news 2026/4/16 16:12:18

C++多线程编程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++多线程编程

我们可以把“多线程编程 (Multi-threaded Programming)”理解为“并发管理”

1. 核心比喻:厨房与厨师

  • 进程 (Process)=一家餐厅(厨房)

    • 它有独立的冰箱(内存)、独立的煤气管道(资源)。

    • 餐厅倒闭了(进程崩溃),里面的东西都没了。

  • 线程 (Thread)=厨房里的厨师

    • 单线程:厨房里只有一个厨师。他必须先切菜,切完再炒菜,炒完再装盘。客人等得花儿都谢了。

    • 多线程:厨房里有三个厨师

      • 厨师 A 负责切菜。

      • 厨师 B 负责炒菜。

      • 厨师 C 负责装盘。

    • 优势:大家同时干活,效率极高(利用多核 CPU)。

    • 风险:他们共享同一个冰箱(内存/PlanContext)。如果厨师 A 正在拿肉,厨师 B 突然把冰箱门关了夹住 A 的手,或者两人同时抢一把刀,就会出事。


2. 为什么要搞多线程?(自动驾驶场景)

在你的PlanningNode里,如果只有单线程,代码是这样跑的:

  1. 等激光雷达数据进来(耗时 10ms)...

  2. 等定位数据进来(耗时 5ms)...

  3. 开始规划路径(耗时 50ms)...

  4. 发送控制指令。

后果:车子在等数据的时候是“发呆”的,规划频率极其低下,车子开起来一顿一顿的,甚至会因为反应慢撞墙。

引入多线程后:

  • 线程 1(收发员):专门负责收 ROS 消息(Callback)。有数据来就塞进PlanContext,不用等规划算完。

  • 线程 2(计算员):专门负责算 OSQP(Timer Loop)。不管有没有新数据,我每 100ms 必须算一次,保证车子一直有指令。

这就是“异步高效”的本质。


3. 多线程编程的三个核心要素

在 C++ 代码中,你主要会遇到这三个东西:

A. 创建线程 (Create)
#include <thread> void task() { // 具体的干活逻辑 } int main() { std::thread t1(task); // 创建并启动线程 t1 t1.detach(); // 让它自己去跑,不管它了 // 或者 t1.join(); // 主线程在这里等,直到 t1 干完活才继续 }
B. 资源共享 (Sharing)

就像大家共用一个冰箱。

在你的项目中,PlanContext就是那个最大的共享资源。

  • ROS 回调线程往里面写。

  • 规划主线程从里面读。

C. 同步与互斥 (Synchronization & Mutex)

这是最难的地方。因为大家共用资源,所以必须立规矩。

  • 竞态条件 (Race Condition):两个线程同时改一个变量,导致结果错误。(就是刚才说的“抢刀”)。

  • 互斥锁 (Mutex):解决竞态条件的工具。(刚才讲的“试衣间锁”)。

  • 死锁 (Deadlock)

    • 厨师 A 拿着刀,等锅。

    • 厨师 B 拿着锅,等刀。

    • 两人僵持不下,厨房彻底停摆。


4. 你的代码架构中的体现

回头看你的架构图,多线程是这样运作的:

  1. ROS 2 的底层:ROS 2 默认就是一个多线程的中间件。当你定义了多个Subscription(订阅)时,ROS 内部会有线程池(Executor)帮你去“监听”数据。

  2. 回调并发:当LocalizationPose(定位)和ObstacleArray(感知)同时到达时,可能会有两个不同的线程同时试图调用PlanContext::updateData

  3. 保护机制:所以PlanContext里必须有std::mutex。谁先抢到锁,谁先写,另一个排队。

5.提醒:

  1. 敬畏全局变量:只要你定义了一个全局变量或者静态变量(单例),就要立刻想到:“这会被多个线程同时访问吗?”

  2. 加锁要用 RAII:永远使用std::lock_guardstd::unique_lock,不要手动lock()unlock(),防止死锁。

  3. 多看 Log:多线程的 Bug 很难复现(因为是概率性的)。如果程序偶尔崩溃,大概率是哪里没加锁。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 13:02:52

需求分级:助力集成商为客户交付传输需求分级与优先级保障方案

识别传输需求、实施优先级管理、对齐传输标准 摘要 为设备集成商、IT外包公司、宽带组网运营商及楼宇企服资源方等技术服务伙伴赋能&#xff0c;结合可视化运行监控系统&#xff0c;提供系统规划、标准化交付与平台化运维支撑&#xff0c;助力其为客户实现高确定性的ICT交付。…

作者头像 李华
网站建设 2026/4/16 11:12:06

运行标准:助力运维商为客户交付高可用网络运行标准体系

建立设备冗余标准、定义系统运行指标、确保传输资源连通性 摘要 本文为设备集成商、IT外包公司、宽带组网运营商及楼宇企服资源方等技术服务伙伴赋能&#xff0c;结合可视化运行监控系统&#xff0c;提供系统规划、标准化交付与平台化运维支撑&#xff0c;助力其为客户实现高…

作者头像 李华
网站建设 2026/4/3 6:45:24

打卡信奥刷题(2755)用C++实现信奥题 P3718 [AHOI2017初中组] alter

P3718 [AHOI2017初中组] alter 题目描述 有 nnn 盏灯排成一列&#xff0c;其中有些灯开着&#xff0c;有些灯关着。小可可希望灯是错落有致的&#xff0c;他定义一列灯的状态的不优美度为这些灯中最长的连续的开着或关着的灯的个数。小可可最多可以按开关 kkk 次&#xff0c;每…

作者头像 李华
网站建设 2026/4/16 15:52:46

多模态大模型工作原理详解:视觉与语言信息如何在MLLMs中融合与传播?

本研究首次系统性分析多模态大语言模型内部跨模态信息流动机制&#xff0c;通过注意力屏蔽方法发现视觉信息通过三阶段传播&#xff1a;低层整合全局视觉特征&#xff0c;中层提取问题相关视觉信息&#xff0c;高层进行最终预测。这一发现揭示了LLaVA系列模型中信息流动的一致模…

作者头像 李华
网站建设 2026/4/16 11:14:08

一文搞定多级标题自动编号

在撰写长文档或技术报告时&#xff0c;多级标题的自动编号往往让人头疼。尤其是当需求超过 4 级&#xff0c;涉及到 1.1.1.1、(1)、1) 甚至 ① 的混合排版时&#xff0c;手动输入不仅效率低&#xff0c;还极易出错。 本文将带你彻底搞定 Word 和 WPS 中的多级列表排版&#xf…

作者头像 李华