单例模式(Singleton Pattern)是设计模式中最简单的形式之一,其目的是使得类的一个对象成为系统中的唯一实例。
这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。这个类提供了一种访问其唯一对象的方式,可以直接访问,不需要实例化该类的对象。
单例模式的要点有三个:
- 单例类有且仅有一个实例
- 单例类必须自行创建自己的唯一实例
- 单例类必须给所有其他对象提供这一实例
从具体实现角度来说,可分为以下三点:
- 提供一个 private 构造函数(防止外部调用而构造类的实例)
- 提供一个该类的 static private 对象
- 提供一个 static public 函数,用于创建或获取其本身的静态私有对象(例如:GetInstance())
除此之外,还有一些关键点(需要多加注意,很容易忽视):
- 线程安全(双检锁 - DCL,即:double-checked locking)
- 资源释放
#ifndef SINGLETON_H
#define SINGLETON_H
#include <QMutex>
#include <QDebug>
//单例 自动释放
class Singleton
{
public:
static Singleton* GetInstance();
private:
Singleton(){}
private:
static Singleton *m_pSingleton;
class GC//垃圾回收机制
{
public:
~GC()
{
// 可以在这里销毁所有的资源,例如:db 连接、文件句柄等
if (m_pSingleton != NULL)
{
qDebug() << "m_pSingleton destroy...";
}
}
static GC gc;
};
private:
static QMutex m_mutex;
};
#endif
//(双检锁 DCL 机制) double check lock
Singleton* Singleton::m_pSingleton = NULL;//在cpp中定义 在头文件中定义当重复包含时会出现多次定义的情况
QMutex Singleton::m_mutex;
Singleton *Singleton::GetInstance()
{
//第一次调用初始化 非多线程安全
if (m_pSingleton == NULL)
{
m_mutex.lock();//加锁后多线程安全 自解锁
if (m_pSingleton == NULL)
{
m_pSingleton = new Singleton();
}
}
return m_pSingleton;
}
原文地址 http://blog.youkuaiyun.com/liang19890820/article/details/61615495