C++实现单例模式

单例模式

单例模式属于创建性的模式, 它提供了一种创建对象的最佳方法,他设计到一个单一的类,也就是说,一个类只能实例化一个对象. 并且还需要给其他对象提供全局访问点.

单例模式的实现方式主要有 饿汉模式 和 懒汉模式

饿汉模式
饿汉模式的意思是, 无论程序将来是否使用这个类, 在程序已启动的时候,就对对象进行实例化
饿汉模式的实现需要在类的内部就对声明一个该类静态成员对象, 并且在类外进行初始化, 之后在类中提供一个静态的接口去获取之歌静态的成员. 除此之外, 还要对构造函数进行私有化.
C++实现单例模式_第1张图片

饿汉模式的特点:

  1. 优点:实现比较的简单
  2. 缺点: 由于是在程序启动的时候对单一对象进行实例化,.因此,会使程序的启动时间较长
  3. 使用场景 : 在多线程高并发的情况下使用时.

懒汉模式
懒汉模式顾名思义就是,先不去对对象进行实例化, 因为有可能这个对象中的一些操作如文件的读取在程序运行的时候用不到, 程序启动时只创建一个类类型的指针, 当第一次要使用实例对象时, 在对这个对象进行实例化.

注意 : 有于懒汉模式是在第一次使用对象的时候对其进行初始化,因此当有多线程执行程序是,会存在线程安全的问题, 如不考虑线程安全,就会造成有多个对象被实例化, 这就不是单例模式了!因此,在判断对类的指针是否为空前需要用到互斥锁,保证线程安全

class singleton{
	public:
		//提过静态的接口获取单一对象
		static GetSingleton(){
			if(_ptr==nullptr){
				_mtx.lock()
				if(_ptr==nullptr){
					_ptr=new singleton();
				}
				_mutex.unlock();
			}
			return _ptr;
		}
	private:
		//将构造,拷贝构造,赋值运算符私有化
		sinleton(){}
		singleton(singleton const& s){}
		singleton& operator=(sngleton const& s){}
		//定义指针以及互斥锁
		static singleton* _ptr;
		static mutex _mtx;
};
//对静态成员在类外进行初始化
singleton* singleton::_ptr=nullptr;
mutex singleton::_mtx;

==注意 : 当有多个线程执行的时候, 为了避免过多的线程等待在加锁的操作上, 因此使用了双重的判断语句, 这样可以更好的提高效率

懒汉模式的特点

  1. 优点 : 由于不需要程序在运行的时候对对象进行实例化, 因此程序启动的时候回比较快
  2. 缺点 : 懒汉模式的实现比较复杂, 当程序执行的过程中需要使用单例对象的时候,程序运行的会比较慢.

你可能感兴趣的:(C++)