c++单例模式

一、作用:主要是确保一个类仅有一个实例,并提供一个全局访问点来获取这个实例。常见的有懒汉式和饿汉式。

二、懒汉式(线程不安全):在第一次使用时实例化对象。基本的懒汉式实现并不支持多线程环境,因为在多线程环境下可能会创建多个实例。

cpp 复制代码
#include <iostream>

class Singleton
{
private:
    static Singleton *instance;
    Singleton() {} // 构造函数私有

public:
    static Singleton *getInstance()
    {
        if (instance == nullptr)
        {
            instance = new Singleton();
        }
        return instance;
    }
    // 虚析构函数,用于确保子类能够正确释放资源
    virtual ~Singleton()
    {
        delete instance;
        instance = nullptr;
    }
    Singleton(const Singleton &) = delete;
    Singleton &operator=(const Singleton &) = delete;
};

// 静态成员变量需要在类外初始化
Singleton *Singleton::instance = nullptr;

int main()
{
    Singleton *s1 = Singleton::getInstance();
    Singleton *s2 = Singleton::getInstance();

    // s1和s2指向同一个实例
    std::cout << ((s1 == s2) ? "Same instance" : "Different instance") << std::endl;
    return 0;
}

三、饿汉式:在程序启动时即创建实例,因此不存在多线程访问时创建多个实例的问题。

cpp 复制代码
#include <iostream>

class Singleton
{
private:
    static Singleton instance;
    Singleton() {} // 构造函数私有

public:
    static Singleton &getInstance()
    {
        return instance;
    }
    // 虚析构函数,用于确保子类能够正确释放资源
    virtual ~Singleton()
    {
    }
    Singleton(const Singleton &) = delete;
    Singleton &operator=(const Singleton &) = delete;
};

// 静态成员变量需要在类外初始化
Singleton Singleton::instance;

int main()
{
    Singleton &s1 = Singleton::getInstance();
    Singleton &s2 = Singleton::getInstance();

    // s1和s2引用同一个实例
    std::cout << ((&s1 == &s2) ? "Same instance" : "Different instance") << std::endl;
    return 0;
}

饿汉式单例模式由于其实现简单且线程安全(实例在程序启动时被创建),是实际应用中较为常见的选择。

相关推荐
逝水如流年轻往返染尘7 小时前
设计模式之单例模式
单例模式·设计模式
rKWP8gKv72 天前
单例模式在Java中的7种实现:从懒汉式到静态内部类
java·开发语言·单例模式
likerhood5 天前
单例模式详细讲解(java)
java·开发语言·单例模式
无敌秋6 天前
C++ 单例模式
c++·单例模式
风筝在晴天搁浅6 天前
手撕单例模式
java·开发语言·单例模式
txxzjmzlh7 天前
多线程案例--单例模式
单例模式
要开心吖ZSH8 天前
枚举单例模式详解-为什么需要枚举单例?
单例模式
凤头百灵鸟8 天前
Python语法进阶篇 --- 单例模式、魔法方法
javascript·python·单例模式
原来是猿9 天前
线程安全的单例模式
linux·服务器·开发语言·单例模式·策略模式