设计模式--单例模式(二)登记式

本文介绍了登记式单例模式,通过维护一个Map来管理不同名称的单例对象。当获取实例时,若Map中不存在,则创建并登记;已存在则直接返回。文章通过实例展示了如何使用登记式单例模式,包括固定和不固定数量的单例,并分析了其优缺点,特别是当构造方法被直接调用时可能导致的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文是设计模式学习笔记的第二篇文章,主要分析的是单例模式。包括懒汉式,饿汉式,登记式,以及懒汉式的改进型,
还有一个关于读取propertoes配置文件的实例。现在看来要写四节了。这是第二节,上一节分析了最基本的懒汉式和饿汉式,
这次我们来看一下登记式。


登记式实际对一组单例模式进行的维护,主要是在数量上的扩展,通过map我们把单例存进去,这样在调用时,先判断该单例是否已经创建,是的话直接返回,不是的话创建一个登记到map中,再返回。对于数量又分为固定数量和不固定数量的。下面采用的是不固定数量的方式,在getInstance方法中加上参数(string name)。然后通过子类继承,重写这个方法将name传进去。让我们看看代码吧


首先是父类:

//采用Map配置多个单例
public class MySingleton3 {
	
	// 设立静态变量,直接创建实例
	private static Map<String, MySingleton3> map = new HashMap<String, MySingleton3>();
		
	// -----受保护的-----构造函数,不能是私有的,但是这样子类可以直接访问构造方法了
	//解决方式是把你的单例类放到一个外在的包中,以便在其它包中的类(包括缺省的包)无法实例化一个单例类。
	protected MySingleton3() {
		System.out.println("-->私有化构造函数被调用,创建实例中");
		
	}

	// 开放一个公有方法,判断是否已经存在实例,有返回,没有新建一个在返回
	public static MySingleton3 getInstance(String name) {
		if (name == null) {
			name = MySingleton3.class.getName();
			System.out.println("-->name不存在,name赋值等于"+MySingleton3.class.getName());
		}
		if (map.get(name) == null) {
			try {
				System.out.println("-->name对应的值不存在,开始创建");
				map.put(name, (MySingleton3)Class.forName(name).newInstance());
			} catch (InstantiationException e) {
				e.printStackTrace();
			} catch (IllegalAccessException e) {
				e.printStackTrace();
			} 
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值