设计模式之单例模式的实现

  • 单例模式属于创建型设计模式,确保某个类只有一个实例,而且自行实例化并向整个系统提供这个实例。在计算机系统中,线程池、缓存、日志对象、对话框、打印机、显卡的驱动程序对象常被设计成单例。这些应用都或多或少具有资源管理器的功能。每台计算机可以有若干个打印机,但只能有一个打印服务,以避免两个打印作业同时输出到打印机中。每台计算机可以有若干通信端口,系统应当集中管理这些通信端口,以避免一个通信端口同时被两个请求同时调用。选择单例模式可以避免状态不一致。
  • 饿汉式 ( 类初始化时自行实例化 )
public final class Singleton {
	private Singleton() {}
	private static final Singleton singleton = new Singleton();
	public static Singleton getInstance() {
		return singleton;
	}
} 
  • 懒汉式 ( 第一次调用时实例化 )
public final class Singleton {
	private Singleton() {}
	private volatile static Singleton singleton;
	public static Singleton getInstance() {
		if (null == singleton) {
			synchronized (Singleton.class) {
				if (null == singleton) {
					singleton = new Singleton();
				}
			}
		}
		return singleton;
	}
}
  • 静态内部类 ( 嵌套类,在被使用时加载,仍属于懒汉式 )
public final class Singleton {
	private static class LazyHolder {
			private static final Singleton INSTANCE = new Singleton();
	}
	private Singleton() {}
	public static Singleton getInstance() {
		return LazyHolder.INSTANCE;
	}
} 
  • enum方式
public class Singleton {
	private Singleton() {}
	private enum SingletonEnum {
		INSTANCE;
		private Singleton singleton;
		// enum的构造方法必须为private(private修饰符多余i)
		private SingletonEnum() {
			singleton = new Singleton();
		}
		public Singleton getInstance() {
			return singleton;
		}
	}
	public static Singleton getInstance() {
		return SingletonEnum.INSTANCE.getInstance();
	}
}
  • 登记式 ( 扩展数量,对一组单例模式进行维护;可继承 )
public class RegSingletonManager {
	private static Map<String, RegSingletonManager> singletonsMap = new HashMap<>();
	static {
		RegSingletonManager rsm = new RegSingletonManager();
		singletonsMap.put(rsm.getClass().getName(), rsm);
	}
	// 保护的构造器(供子类使用)
	protected RegSingletonManager() {}
	public static RegSingleton getInstance(String name) {
		if (null == name) {
			name = "xxx.RegSingletonManager";
		}
		if (null == singletonsMap.get(name)) {
			try {
				singletonsMap.put(name, Class.forName(name).newInstance());
			} catch (Exception e) { ... }
		}
		return (RegSingletonManager) (singletonsMap.get(name));
	}
}
  • 在实际实现单例模式的过程中,我们需要同时关注以下几种行为创建实例时可能导致的问题:new方法,克隆,反射,序列化。这个问题可以自行设计场景进行分析并完善以上基础的单例设计。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值