博客
关于我
设计模式 --- 单例模式(Singleton)
阅读量:220 次
发布时间:2019-03-01

本文共 1827 字,大约阅读时间需要 6 分钟。

单例模式是一种软件设计模式,其核心思想是确保在程序的任何地方,一个类只能有一个实例对象。这一模式特别适用于那些在程序中需要频繁使用且功能相对单一的类,例如数据库连接管理、资源配置等场景。

单例模式的主要优势在于能够有效管理内存资源,避免不必要的重复加载和占用内存空间。例如,假设有一个类的职责是将数据库加载到内存中并提供只读接口给其他组件使用。如果不采用单例模式,每次生成该类对象时都需要重新加载数据库,会导致内存占用重复,影响系统性能。

在C++11中,实现单例模式有多种方式。以下是常见的三种实现方法:

  • 从stack上分配内存,并返回类对象的引用

    这种实现方式通过使用静态变量来管理单例对象,确保每次调用返回同一个实例。代码示例如下:

    class Database {protected:   Database() {}public:   static Database& get() {      static Database database; // 静态变量      return database;   }   Database(Database const&) = delete;   Database(Database&) = delete;   Database& operator=(Database const&) = delete;   Database& operator=(Database&) = delete;};

    通过在get()方法中定义静态对象database,确保每次调用get()返回的都是同一个实例。这种实现方式在C++11中是线程安全的,但在低于C++11的编译器版本中,可能需要额外的锁机制来保证线程安全。

  • 从heap上分配内存,同样返回引用

    这种实现方式通过动态内存分配来管理单例对象。代码示例如下:

    class Database {protected:   Database() {}public:   static Database& get() {      static Database* pDatabase = new Database(); // 静态指针      return *pDatabase;   }   Database(Database const&) = delete;   Database(Database&) = delete;   Database& operator=(Database const&) = delete;   Database& operator=(Database&) = delete;};

    通过静态指针pDatabase管理单例对象,确保每次调用get()返回同一个实例。这种实现方式在内存管理上相对低效,但在某些特定场景下可能更具灵活性。

  • 返回指针

    这种实现方式通过返回指针来间接管理单例对象。代码示例如下:

    class Database {protected:   Database() {}public:   static Database* get() {      static Database* pDatabase = new Database(); // 静态指针      return pDatabase;   }   Database(Database const&) = delete;   Database(Database&) = delete;   Database& operator=(Database const&) = delete;   Database& operator=(Database&) = delete;};

    通过静态指针pDatabase管理单例对象,确保每次调用get()返回同一个实例。这种实现方式与第二种方法类似,但直接返回指针可能会带来一定的内存管理风险。

  • 需要注意的是,以上实现方式都通过删除构造函数和赋值操作来防止用户从其他地方创建新的实例,从而强制性地将单例模式的控制权掌握在get()方法中。这种设计方式虽然保证了单例模式的实现,但也需要谨慎处理异常情况和内存释放。

    总的来说,单例模式通过确保类只能有一个实例化对象,有效地减少了内存占用和资源浪费,提升了程序的性能和稳定性。在实际开发中,可以根据具体需求选择合适的实现方式,并结合线程安全的需求进行必要的优化。

    转载地址:http://ziav.baihongyu.com/

    你可能感兴趣的文章
    OSPF技术连载13:OSPF Hello 间隔和 Dead 间隔
    查看>>
    OSPF技术连载17:优化OSPF网络性能利器——被动接口!
    查看>>
    OSPF技术连载18:OSPF网络类型:非广播、广播、点对多点、点对多点非广播、点对点
    查看>>
    OSPF技术连载19:深入解析OSPF特殊区域
    查看>>
    SQL Server 复制 订阅与发布
    查看>>
    OSPF技术连载20:OSPF 十大LSA类型,太详细了!
    查看>>
    OSPF技术连载21:OSPF虚链路,现代网络逻辑连接的利器!
    查看>>
    OSPF技术连载22:OSPF 路径选择 O > O IA > N1 > E1 > N2 > E2
    查看>>
    OSPRay 开源项目教程
    查看>>
    Padding
    查看>>
    paddlehub安装及对口罩检测
    查看>>
    paddle的两阶段基础算法基础
    查看>>
    Page Object模式:为什么它是Web自动化测试的必备工具
    查看>>
    SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
    查看>>
    PageHelper 解析及实现原理
    查看>>
    pageHelper分页工具的使用
    查看>>
    PageHelper:上手教程(最详细)
    查看>>
    PageOffice如何实现从零开始动态生成图文并茂的Word文档
    查看>>
    PageRank算法
    查看>>
    Paint类(画笔)
    查看>>