0

0

C++怎么实现一个单例设计模式_C++面向对象设计与Singleton模式最佳实践

下次还敢

下次还敢

发布时间:2025-11-27 12:34:34

|

583人浏览过

|

来源于php中文网

原创

单例模式确保类唯一实例并提供全局访问点,常用于日志、配置管理等场景。最简单实现为私有构造函数加静态指针的懒汉式,但存在内存泄漏和线程安全问题。C++11起推荐使用局部静态变量实现,因编译器保证初始化线程安全且自动析构,代码简洁高效。若需兼容旧标准或精细控制生命周期,可结合互斥锁与智能指针实现线程安全的懒加载,虽性能略低但可控。最佳实践包括优先采用局部静态变量方式、禁用拷贝与赋值、避免手动内存管理,并注意析构顺序及测试支持。正确选择实现方式可兼顾安全性与效率。

c++怎么实现一个单例设计模式_c++面向对象设计与singleton模式最佳实践

单例模式(Singleton Pattern)是C++中最常用的创建型设计模式之一,确保一个类只有一个实例,并提供一个全局访问点。在实际开发中,常用于日志管理器、配置管理器、线程池等需要唯一实例的场景。

基本单例结构

最简单的单例实现方式是将构造函数设为私有,定义一个静态成员函数返回唯一实例:

class Singleton {
private:
    static Singleton* instance;
    Singleton() = default;  // 私有构造
    Singleton(const Singleton&) = delete;
    Singleton& operator=(const Singleton&) = delete;

public: static Singleton* getInstance() { if (instance == nullptr) { instance = new Singleton(); } return instance; } };

// 静态成员定义 Singleton* Singleton::instance = nullptr;

这种方式称为“懒汉式”,对象在首次调用 getInstance() 时创建。但存在两个问题:未释放内存(可能造成泄漏),且在多线程环境下不安全。

线程安全与自动释放

为解决线程安全和资源释放问题,推荐使用局部静态变量 + 函数内定义的方式,利用C++11之后的“局部静态变量初始化线程安全”特性:

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

灵光
灵光

蚂蚁集团推出的全模态AI助手

下载
class Singleton {
private:
    Singleton() = default;
    ~Singleton() = default;
    Singleton(const Singleton&) = delete;
    Singleton& operator=(const Singleton&) = delete;

public: static Singleton& getInstance() { static Singleton instance; // C++11 起线程安全 return instance; } };

这种写法简洁高效,编译器保证静态局部变量只初始化一次,且在程序退出时自动析构。这是目前最推荐的基础实现方式。

支持延迟构造与显式控制

若需更精细控制生命周期或兼容旧标准(如C++03),可结合互斥锁和智能指针实现线程安全的懒加载

#include 
#include 

class Singleton { private: static std::unique_ptr instance; static std::mutex mtx;

Singleton() = default;
~Singleton() = default;

public: static Singleton& getInstance() { std::lock_guard<:mutex> lock(mtx); if (!instance) { instance = std::make_unique(); } return *instance; } };

std::unique_ptr Singleton::instance = nullptr; std::mutex Singleton::mtx;

这种方式适用于必须延迟构造且运行环境不支持C++11的情况。虽然性能略低,但能精确控制初始化时机。

最佳实践建议

  • 优先使用局部静态变量方式(C++11起),代码简洁且安全。
  • 避免动态分配内存后手动管理,防止泄漏。
  • 禁止拷贝和赋值操作,明确删除相关函数。
  • 若单例依赖其他模块,注意析构顺序问题,必要时使用“Cheshire Cat”或指针封装。
  • 测试时可通过友元类或重置方法辅助单元测试,但生产环境慎用。

基本上就这些。单例模式看似简单,但在多线程、生命周期管理上容易出错。选择合适实现方式,兼顾效率与安全性,才是面向对象设计中的最佳实践。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

757

2023.08.22

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

56

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

50

2025.11.27

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

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

482

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

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

5

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

8

2026.01.21

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

2

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

40

2026.01.21

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
nginx浅谈
nginx浅谈

共15课时 | 0.8万人学习

前端开发(基础+实战项目合集)
前端开发(基础+实战项目合集)

共60课时 | 3.9万人学习

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

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