news 2026/5/19 17:45:56

C++单例模式 (Singleton Pattern)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++单例模式 (Singleton Pattern)

单例模式 (Singleton Pattern)是软件设计模式中最基础、也是自动驾驶系统中最常用的一种模式。

为了让你彻底理解,我们还是用生活例子,结合代码来拆解。


一、 核心概念:

单例模式的定义:确保一个类只有一个实例 (Instance),并提供一个全局访问点来获取它。

生活中的例子:
  • 公司公章:只有一枚。谁要盖章,都得去找那一枚章。

代码中的含义:

在你的代码里,PlanContext就是那个“公章”。

  • 错误的做法:每次要用数据,就new PlanContext()

    • 后果:感知模块往“公章A”里写了障碍物,规划模块去“公章B”里读数据。结果读了个寂寞,车子撞墙。

  • 单例的做法:全程序禁止new,只能通过一个特定的函数(比如Instance())拿到那唯一的一个对象。


二、 C++ 代码怎么写?

这是 C++11 之后最标准、最简洁、线程安全的写法(被称为Meyers' Singleton)。请把这段代码刻在脑子里:

class PlanContext { private: // 1. 构造函数私有化 (Private Constructor) // 意思:禁止外部随便 new!只有我自己能生我自己。 PlanContext() { std::cout << "PlanContext 初始化了(只会出现一次)" << std::endl; } public: // 2. 删除拷贝构造和赋值操作 (Delete Copy) // 意思:禁止克隆!禁止影分身!保证独一无二。 PlanContext(const PlanContext&) = delete; void operator=(const PlanContext&) = delete; // 3. 全局访问点 (Global Access Point) // 意思:想要用我?调这个函数。 static PlanContext& Instance() { // 关键点:static 局部变量 // 特性:C++11 保证了它是线程安全的,且只会初始化一次 static PlanContext instance; return instance; } // --- 具体的业务数据 --- void updateData() { ... } }; // 使用方法: int main() { // PlanContext p = new PlanContext(); // 报错!不让你 new // 正确用法:直接找 Instance 要 PlanContext::Instance().updateData(); }

三、 为什么PlanContext必须是单例?

结合你的架构图,原因有两个:

1. 数据一致性 (Data Consistency)

你的系统是一个流水线:感知 -> 写入 -> PlanContext -> 读取 -> 规划如果PlanContext不是单例,感知写到了对象 A,规划读的是对象 B,那规划模块永远拿不到最新的路况。只有大家共用一个对象,才能保证**“你写的就是我读的”**。

2. 节省资源 (Resource Management)

虽然PlanContext可能不大,但如果是一些像MapEngine(地图引擎)这样的类,加载一次地图要吃掉 2GB 内存。如果你不小心new了 10 次,20GB 内存没了,电脑直接死机。单例保证了它只占一份内存。


四、 单例模式的“坑”

虽然它好用,但也不要滥用。

  1. 它本质上是全局变量: 因为谁都能访问它,谁都能改它。如果代码里哪个角落偷偷改了数据,很难查出来是谁干的。(所以我们要加Mutex锁来保护)。

  2. 生命周期难以控制: 它通常在程序启动时出生,程序结束时销毁。如果你想中途把它销毁释放内存,比较麻烦。

五、 总结

当你看到代码里写着::Instance()或者::getInstance()时,脑子里要立刻反应过来:

  1. 这是一个单例。

  2. 全公司只有这一份。

  3. 大家都在抢着用它,所以里面肯定有锁 (Mutex)。

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

接入系统:支撑IT外包公司为客户交付可靠接入系统部署方案

分配接入系统资源、配置系统交换路由、落实接入层冗余标准 摘要 本文为设备集成商、IT外包公司、宽带组网运营商及楼宇企服资源方等技术服务伙伴赋能&#xff0c;结合可视化运行监控系统&#xff0c;提供系统规划、标准化交付与平台化运维支撑&#xff0c;助力其为客户实现高…

作者头像 李华
网站建设 2026/5/16 10:25:22

传输标准:助力设备商为客户交付高质量传输网负载方案

制定传输资源分级标准、实施路由系统负载配置、达成广域网路由连通指标 摘要 本文面向设备集成商、IT外包公司、宽带组网运营商及楼宇企服资源方等技术服务伙伴&#xff0c;结合可视化运行监控系统&#xff0c;提供系统规划、标准化交付与平台化运维支撑&#xff0c;助力其为…

作者头像 李华
网站建设 2026/5/12 12:13:53

运维分析:支撑运维商为客户交付局域网深度诊断方案

开展局域网设备故障分析、实施局域网冗余分析、执行局域网路由分析 摘要 针对设备集成商、IT外包公司、宽带组网运营商及楼宇企服资源方等技术服务伙伴&#xff0c;依托可视化运行监控系统&#xff0c;提供系统规划、标准化交付与平台化运维支撑&#xff0c;赋能其为客户实现…

作者头像 李华
网站建设 2026/5/13 21:13:33

服装企业选ERP:开发版单和物料管理哪家更实用?

很多服装企业在考虑ERP选型时&#xff0c;最容易纠结的就是一个问题&#xff1a; “我们现在想上ERP&#xff0c;到底选哪家系统更实用&#xff1f;金蝶、用友、行业专用ERP、低代码自建&#xff0c;甚至MESPLM组合都有方案&#xff0c;到底该怎么选&#xff1f;” 说白了&…

作者头像 李华
网站建设 2026/5/16 19:50:11

MLLM Token压缩技术研究综述:解决大模型高计算成本的实用指南

多模态大模型(MLLM)处理高分辨率图像和长视频时面临巨大计算成本&#xff0c;Token压缩技术成为解决方案。本文基于压缩位置系统分类了现有方法&#xff0c;包括Vision Encoder、Projector和LLM模块中的压缩策略&#xff0c;以及多模块协同压缩。同时针对不同场景提供了选择合适…

作者头像 李华