用单例模式来讲解c++11新特性

单例模式定义

保证一个类仅有一个实例,并提供一个该实例的全局访问点。
——《设计模式》

代码一

#include <stdlib.h>
using namespace std;

class Singleton {
   
public:
    static Singleton* GetInstance(){
   
        if(_instance == nullptr){
   
            _instance = new Singleton();
        }
        return _instance;
    }

private:
    Singleton(){
   };  //普通构造
    ~Singleton(){
   };
    Singleton(const Singleton &) = delete; //拷贝构造
    Singleton& operator=(const Singleton &) = delete; //拷贝赋值构造
    Singleton(Singleton &&) = delete;  //移动构造
    Singleton& operator=(Singleton &&) = delete; //移动拷贝构造

    static Singleton *_instance;
}
Singleton* Singleton::_instance = nullptr;

代码一说明

在单例模式中,为了确保一个类对应一个实例,不仅要考虑只能创建一个实例,而且要考虑创建一个实例后,这个实例又被调用去创建另一个实例。所以,要将普通构造和析构函数设置为私有,然后禁用四类特殊构造函数。在这里就使用了c++11的新特性:Singleton(const Singleton &) = delete,可以实现将某个构造函数禁用的功能。

代码一的问题

没有安全地释放内存,而且私有的析构函数不能在外部调用,无法灵活地释放动态内存,容易造成内存泄漏,所以需要加一个静态的释放内存的接口。

代码二

#include <stdlib.h>
using namespace std;

class Singleton {
   
public:
    static Singleton* GetInstance(){
   
        if(_instance == nullptr){
   
            _instance = new Singleton();
            atexit(Destructor);
        }
        return _instance;
    }

private:
    static void Destructor(){
   
        if(nullptr != _instance){
   
            delete _instance;
            _instance = nullptr;
        }
    }
    Singleton(){
   };  //普通构造
    ~Singleton()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值