单例模式的实现

本文深入探讨了单例模式的两种实现方式:饿汉式和懒汉式。通过具体代码示例,介绍了这两种模式的特点和应用场景,帮助读者理解如何在不同情况下选择合适的单例模式。
部署运行你感兴趣的模型镜像

#include <iostream>
using namespace std;
//单例模式:即单个实例的模式(面向对象,一个类只允许产生一个实例,自行实例化,并提供全局的访问方法)
//分类:
//1.饿汉单例:在使用前对象已创建完成,即使还未使用对象,其也一直存在
//实现:用一个已初始化的静态对象指针,用一个接口提供其给用户使用,再将构造函数设为私有,
//所以用户只能使用这个接口得到这个对象,由于此成员对象指针为静态,无论调用多少次其都返回同一个对象
class Singleton1
{
private:
	Singleton1()   //构造函数设为私有防止对象不唯一
	{
		cout<<"Singleton1()"<<endl;
	}
	static Singleton1* intance;  //静态对象指针
public:
	//返回已初始化对象指针
	static Singleton1* GetObject()
	{
		return intance;    
	}
};
Singleton1* Singleton1::intance=new Singleton1();  //静态成员类外初始化
void test1()
{
	cout<<"test1 start:"<<endl;   //测试开始
	//Singleton1 s;
	//Singleton1* ps=new Singleton1();

	Singleton1* P1=Singleton1::GetObject();
	Singleton1* P2=Singleton1::GetObject();
	cout<<(P1==P2)<<endl;   //判断两对象是否为同一个
}

//2.懒汉单例:由于饿汉单例在不使用对象时其也一直存在,占据那块内存,
//所以懒汉单例为在第一次使用对象时在创建初始化此对象,保持资源利用最大化
//实现:其在饿汉单例基础上:首先将静态对象指针成员初始化为NULL,而在提供的静态函数接口中
//首先判断指针是否为空,是则创建对象,不是则表明已经存在一个对象则直接返回它
class Singleton2
{
private:
	Singleton2()   //构造函数设为私有防止对象不唯一
	{
		cout<<"Singleton2()"<<endl;
	}
	static Singleton2* intance;  //静态对象指针
public:
	//返回已初始化对象指针
	static Singleton2* GetObject()
	{
		if(intance==NULL)
		{
			intance=new Singleton2();
		}
		return intance;    
	}
};
Singleton2* Singleton2::intance=NULL;  //静态成员类外初始化
void test2()
{
	cout<<"test2 start:"<<endl;   //测试开始
	//Singleton2 s;
	//Singleton2* ps=new Singleton();

	Singleton2* P1=Singleton2::GetObject();
	Singleton2* P2=Singleton2::GetObject();
	cout<<(P1==P2)<<endl;
}
int main()
{
	test1();
	cout<<endl;
	test2();
	system("pause");
	return 0;
}

结果如下:


您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

### 单例模式实现方法 单例模式是一种设计模式,确保一个类只有一个实例,并提供一个全局访问点。以下是几种常见的实现方式: #### 1. 饿汉式(Eager Initialization) 饿汉式在类加载时就创建实例,线程安全且简单。 ```java public class Singleton { private static final Singleton INSTANCE = new Singleton(); private Singleton() {} public static Singleton getInstance() { return INSTANCE; } } ``` 这种方式的优点是实现简单,线程安全[^1]。缺点是在类加载时就创建实例,可能会浪费资源。 #### 2. 枚举单例模式 枚举单例模式利用 Java 的枚举特性来实现单例,能够防止通过反射或序列化破坏单例。 ```java public enum Singleton { INSTANCE; public void someServiceMethod() { System.out.println("Performing a service"); } } ``` 枚举单例模式不仅自动支持序列化机制,而且通过 JVM 从根本上保证了反射攻击的安全问题[^2]。 #### 3. 静态内部类单例模式 静态内部类单例模式在第一次使用时才创建实例,既延迟加载又线程安全。 ```java public class Singleton { private Singleton() {} private static class SingletonHolder { private static final Singleton INSTANCE = new Singleton(); } public static Singleton getInstance() { return SingletonHolder.INSTANCE; } } ``` 这种方式的优点是实现了懒加载,同时避免了同步锁的开销[^5]。 #### 4. 懒汉式(Lazy Initialization) 懒汉式在需要时才创建实例,但需要处理多线程环境下的安全性问题。 ```java public class Singleton { private static Singleton instance; private Singleton() {} public static synchronized Singleton getInstance() { if (instance == null) { instance = new Singleton(); } return instance; } } ``` 上述实现中使用了 `synchronized` 关键字来确保线程安全,但会带来性能开销。可以通过双重检查锁定优化。 ```java public class Singleton { private static volatile Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == null) { synchronized (Singleton.class) { if (instance == null) { instance = new Singleton(); } } } return instance; } } ``` 双重检查锁定减少了同步的范围,提高了性能[^5]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值