C++实现单例模式

单例模式的概念:只允许产生一个对象的
详细解释: 单例模式,是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中,应用该模式的类一个类只有一个实例。即一个类只有一个对象实例
单例模式实现方法:
  1. 单例类保证全局只有唯一一个自行创建的实例对象
  2. 单例类提供获取这个唯一实例的接口
单例模式的优缺点:
优点:
  1. 阻止其他对象实例化自己的副本,保证所有访问唯一性。
  2. 可以灵活的更改实例化的过程。
缺点:
  1. 每次都要检查对象是不是已经生成,造成多余开销。
  2. 使用单例对象时,开发人员可能会意外发现自己无法实例化该类
单例大约有两种实现方法:
懒汉:故名思义,不到万不得已就不会去实例化类,也就是说在第一次用到类实例的时候才会去实例化,所以上边的经典方法被归为懒汉实现;
饿汉:饿了肯定要饥不择食。所以在单例类定义的时候就进行实例化
特点与选择:
1,由于要进行线程同步,所以在访问量比较大,或者可能访问的线程比较多时, 采用 饿汉实现,可以实现更好的性能。这是以空间换时间。
2,在访问量较小时,采用懒汉实现。这是以时间换空间。
//最简单的单例模式
class singleton
{
protected :
     singleton(){}
private :
     static   singleton* p;
public :
     static   singleton* instance();
};
singleton* singleton::p = NULL;
singleton* singleton::instance()
{
     if   (p == NULL)
         p =   new   singleton();
     return   p;
}
//加锁的经典懒汉实现:
class singleton
{
protected:
singleton()
{
pthread_mutex_init(&mutex);
}
private:
static singleton* p;
public:
static pthread_mutex_t mutex;
static singleton* initance();
};

pthread_mutex_t singleton::mutex;
singleton* singleton::p = NULL;
singleton* singleton::initance()
{
if (p == NULL)
{
pthread_mutex_lock(&mutex);
if (p == NULL)
p = new singleton();
pthread_mutex_unlock(&mutex);
}
return p;
}
//内部静态变量的懒汉实现
class singleton
{
protected:
singleton()
{
pthread_mutex_init(&mutex);
}
public:
static pthread_mutex_t mutex;
static singleton* initance();
int a;
};

pthread_mutex_t singleton::mutex;
singleton* singleton::initance()
{
pthread_mutex_lock(&mutex);
static singleton obj;
pthread_mutex_unlock(&mutex);
return &obj;
}
//饿汉模式
class singleton
{
protected:
    singleton()
    {}
private:
    static singleton* p;
public:
    static singleton* initance();
};
singleton* singleton::p = new singleton;
singleton* singleton::initance()
{
    return p;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值