枚举单例模式
枚举单例模式也是利用JDK底层原理,枚举类其实就是只能创建有限个实例对象的类。因为如果是普通类的话,原则上我们可以完全创建无数实例对象。只要一直new就好了。但是枚举类不行,java规定只能创建有限个实例对象。这也符合实际情况,因为枚举类要表示涵义肯定是有一定数量的事务,比方颜色,交通工具,它客观上不能是无限个。那么如何保证只能有限个实例对象呢,那就是在创建类,就定义好了几个实例对象,所以枚举类也一样,在类加载的时候,就已经初始化好枚举单例对象。并且私有化构造对象,不能新建对象。即使是利用反射技术,也无法创建新的对象。
public enum EnumSingleton {
INSTANCE;
public EnumSingleton getInstance(){
return INSTANCE;
}
}
完整使用枚举单例:
public enum DataSourceEnum {
SQl;
private DBConnection connection = null;
DataSourceEnum() {
connection = new DBConnection();
}
public DBConnection getConnection() {
return connection;
}
}
public class TestSignle {
public static void main(String[] args) {
DBConnection con1 = DataSourceEnum.SQl.getConnection();
DBConnection con2 = DataSourceEnum.SQl.getConnection();
System.out.println(con1 == con2);// true
}
}
容器单例模式
在程序的初始化,将多个单例类型注入到一个统一管理的类中,使用时通过key来获取对应类型的对象,这种方式使得我们可以管理多种类型的单例,并且在使用时可以通过统一的接口进行操作。这种方式是利用了Map的key唯一性来保证单例。
public class ContainerSignle {
private ContainerSignle () {}
private static Map<String, Object> ioc = new HashMap<>();
public static Object getIntance(String className) {
synchronized (ioc) {
if (!ioc.containsKey(className)) {
Object object = null;
try {
object = Class.forName(className).newInstance();
ioc.put(className, object);
} catch ( Exception e) {
e.printStackTrace();
}
return object;
} else {
return ioc.get(className);
}
}
}
}