什么是单例模式?

什么是单例模式呢?

在一个项目中,全局范围内,某个类的实力有且仅有一个,通过这个唯一实例想其他模块提供数据的全局访问,这种模式就叫单例模式。

由于是单例,所以说不能在外部随意调用构造函数,因此要做如下处理:

构造函数私有化,在类内部只调用一次,这个是可控的。

由于使用者在类外部不能使用构造函数,所以在类内部创建的这个唯一的对象必须是静态的,这样就可以通过类型来访问了,为了不破坏类的封装,我们都会把这个静态对象的访问权限设置为私有的。

在类中只有它的静态成员函数才能访问其静态成员变量,所以可以给这个单例类提供一个静态成员函数用于得到这个静态的单例对象。

拷贝函数私有化或者禁用(使用delete)

拷贝赋值操作符重载函数私有化或者禁用

同时单例模式又分为两种处理模式:

饿汉模式

懒汉模式

饿汉模式就是在类加载的时候立刻进行实例化,这样就得到了一个唯一的可用对象。

饿汉模式下是没有线程安全问题的,因为在这种模式下访问单例对象的时候,这个对象已经被创建出来了。

cpp 复制代码
// 饿汉模式
class TaskQueue
{
public:
    // = delete 代表函数禁用, 也可以将其访问权限设置为私有
    TaskQueue(const TaskQueue& obj) = delete;
    TaskQueue& operator=(const TaskQueue& obj) = delete;
    static TaskQueue* getInstance()
    {
        return m_taskQ;
    }
private:
    TaskQueue() = default;
    static TaskQueue* m_taskQ;
};
// 静态成员初始化放到类外部处理
TaskQueue* TaskQueue::m_taskQ = new TaskQueue;

int main()
{
    TaskQueue* obj = TaskQueue::getInstance();
}

懒汉模式是在类加载的时候不去创建这个唯一的实例,而是需要使用的时候再进行实例化。

但是懒汉模式下有线程安全问题,解决的方法有两个:双重检查锁定和静态局部变量。

双重检查锁定的实现流程建议直接去看大丙老师的视频,更容易理解。

静态局部变量:

cpp 复制代码
class TaskQueue
{
public:
    // = delete 代表函数禁用, 也可以将其访问权限设置为私有
    TaskQueue(const TaskQueue& obj) = delete;
    TaskQueue& operator=(const TaskQueue& obj) = delete;
    static TaskQueue* getInstance()
    {
        static TaskQueue taskQ;
        return &taskQ;
    }
    void print()
    {
        cout << "hello, world!!!" << endl;
    }

private:
    TaskQueue() = default;
};

int main()
{
    TaskQueue* queue = TaskQueue::getInstance();
    queue->print();
    return 0;
}
相关推荐
ArabySide14 小时前
【C#】 资源共享和实例管理:静态类,Lazy<T>单例模式,IOC容器Singleton我们该如何选
单例模式·c#·.net core
Ophelia(秃头版17 小时前
经典设计模式:单例模式、工厂模式
java·开发语言·单例模式
狂奔的sherry1 天前
单例模式(巨通俗易懂)普通单例,懒汉单例的实现和区别,依赖注入......
开发语言·c++·单例模式
晨星05273 天前
软件设计模式之单例模式
单例模式·设计模式
code bean5 天前
【wpf】WPF开发避坑指南:单例模式中依赖注入导致XAML设计器崩溃的解决方案
单例模式·wpf
是三好6 天前
单例模式(Singleton Pattern)
java·开发语言·算法·单例模式
青春易逝丶6 天前
单例模式
单例模式
YA3336 天前
java设计模式一、单例模式
java·单例模式·设计模式
枫景Maple7 天前
Unity中多线程与高并发下的单例模式
unity·单例模式·游戏引擎
iiiiaaiashah7 天前
单例模式的mock类注入单元测试与友元类解决方案
java·开发语言·单例模式