1、单例模式
单例模式:一个类只能创建一个对象
为什么使用单例模式:
在多个线程之间,初始化一次socket资源,对资源进行共享
2、实现单例的步骤:
(1)、构造函数私有化
(2)、提供一个全局的静态方法
(3)、在类中定义一个静态指针,指向本类的变量的静态指针变量!!!
3、单例模式---懒汉式
(1)、代码实现
#include<iostream> using namespace std; class Singelton{ private: Singelton(){ cout<<"Singelton 构造函数执行"<<endl; } public: static Singelton *getInstance(){ if(m_psl == NULL){ m_psl = new Singelton; //申请了一个对象的入口地址; } return m_psl; } static void freeInstance(){ if(m_psl){ cout<<"释放对象空间"<<endl; delete m_psl; m_psl = NULL; } } private: static Singelton *m_psl; //静态变量,必须在类外进行初始化,此时才会分配内存空间!!! }; Singelton *Singelton::m_psl = NULL; int main(void){ Singelton *p1 = Singelton::getInstance(); Singelton *p2 = Singelton::getInstance(); if(p1 == p2){ cout<<"是同一个对象"<<endl; }else{ cout<<"不是同一个对象"<<endl; } Singelton::freeInstance(); return 0; }
(2)、运行结果
(3)、懒汉式:
懒汉式:只有在调用相应的方法时,才会构造对象!!!
缺点:每次都要进行判断,程序进行慢!
(4)、懒汉式存在的一个问题:
i、懒汉式遇上多线程,此时就不能保证是单例模式了,可能会创建多个对象,解决方案:同步加锁、解锁机制!
ii、构造函数不是线程安全函数!--->进行线程同步,保证只有一个线程去调用构造函数.其它的线程都要等待,才能保证只构造一个对象!
4、单例模式---饿汉式
(1)代码实现
#include<iostream> using namespace std; class Singelton{ private: Singelton(){ cout<<"Singelton 构造函数执行"<<endl; } public: static Singelton *getInstance(){ return m_psl; } static void freeInstance(){ if(m_psl){ cout<<"释放对象空间"<<endl; delete m_psl; m_psl = NULL; } } private: static Singelton *m_psl; //此时C++编译器并没有分配内存!!! }; Singelton *Singelton::m_psl = new Singelton; int main(void){ cout<<"*********************"<<endl; //执行顺序:先执行静态变量的初始化(此时也就是构造函数),在执> 行主函数中的代码!!! Singelton *p1 = Singelton::getInstance(); Singelton *p2 = Singelton::getInstance(); if(p1 == p2){ cout<<"是同一个对象"<<endl; }else{ cout<<"不是同一个对象"<<endl; } Singelton::freeInstance(); return 0; }
(2)、运行结果
(3)、饿汉式:
饿汉式:不管需不需要对象空间,都先提前布局好对象空间;
缺点:可能存在内存空间的浪费!
5、还有个懒汉式多线程的代码没有实现,那是解决单例中同步问题的方法;
本文出自 “wait0804” 博客,请务必保留此出处http://wait0804.blog.51cto.com/11586096/1885628
原文地址:http://wait0804.blog.51cto.com/11586096/1885628