设计模式--单例模式示例代码

单例模式:


单例模式是一种常用的软件设计模式。在它的核心结构中只包含—个被称为单例的特殊类。
通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统资源。 如果希望在系统中某个类的对象只能存在一个,单例模式是最好的解决方案。

  1. 该类不能被复制。
  2. 该类不能被公开的创造。

实现单例模式的步骤:
1.构造函数私有化
2.增加静态私有的当前类的指针 
3.提供静态对外接口,可以让用户获得单例对象

该私有的构造函数的构造时机上来说也可以分两种情况来构造:

  1. 只有当需要改类的时候去构造(即为懒汉模式)
  2. 在程序开始之前我就先构造好,你到时候直接用就行(即为饿汉模式)

       懒汉式碰到多线程,是线程不安全
       饿汉式是线程安全的,多线程用饿汉式

 

示例:


#include <iostream>
using namespace std;


//单例   分为饿汉式/懒汉式
//        懒汉式碰到多线程,是线程不安全
//        饿汉式是线程安全的,多线程用饿汉式


//懒汉式
class Singleton_Lazy {
private:
	Singleton_Lazy(){}
public:
	static Singleton_Lazy* getInstance(){
		if (NULL == pSingleton) {
			pSingleton = new Singleton_Lazy;
		}
		return pSingleton;
	}

private:
	static Singleton_Lazy* pSingleton;
};
Singleton_Lazy* Singleton_Lazy:: pSingleton = NULL;



//饿汉式
class Singleton_Hungry {
private:
	Singleton_Hungry() {}
public:
	static Singleton_Hungry* getInstance() {
		return pSingleton;
	}

private:
	static Singleton_Hungry* pSingleton;
};
Singleton_Hungry* Singleton_Hungry::pSingleton = new Singleton_Hungry;


void test()
{
	Singleton_Lazy* p1 = Singleton_Lazy::getInstance();
	Singleton_Lazy* p2 = Singleton_Lazy::getInstance();
	if (p1 == p2)
	{
		cout << "两个指针指向同一块内存空间,是单例" << endl;
	}
	else {
		cout << "不是单例模式" << endl;
	}
	Singleton_Hungry* p3 = Singleton_Hungry::getInstance();
	Singleton_Hungry* p4 = Singleton_Hungry::getInstance();
	if (p3 == p4)
	{
		cout << "两个指针指向同一块内存空间,是单例" << endl;
	}
	else {
		cout << "不是单例模式" << endl;
	}

}


int main()
{
	test();

	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿尔兹

如果觉得有用就推荐给你的朋友吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值