之前我写过 单例模式中的饿汉模式和懒汉模式
他们虽然都能实现单例模式 但是优缺点很明显
饿汉模式:不能懒加载(类加载就会被实例化),消耗很大,在并发情况下安全性很高。
懒汉模式:能实现懒加载,但是在并发情况下安全性不是很高。虽然一步一步的优化,安全性得到了保证,但是却使用了synchronized 对性能有所影响。
今天记录一下 Holder 模式
它结合了饿汉模式 安全性,也结合了懒汉模式懒加载。不会使用synchronized 所以性能也有所保证。
代码:Holder 模式与其说是 饿汉模式和懒汉模式相结合,不如说是思维的更高一层的表现。23种设计模式是(短期)不会变的,但是思想会变。
Holder 模式就是将我们要构造的实例交于其内部类进行实例。
private :表明不能被他人调用,
static: 静态的内部类 不会率先被加载,只有主类被调用的时候被加载(解决了懒加载问题),并且
private static HolderSingleton instance=newHolderSingleton(); 只会加载一次。
/*** Holder模式*/
public classHolderSingleton {privateHolderSingleton(){}/*** 私有的 静态 内部类
类级的内部类,也就是静态的成员式内部类,该内部类的实例与外部类的实例 没有绑定关系,而且只有被调用到时才会装载,从而实现了延迟加载。*/
private static classHolderDemo{private static HolderSingleton instance=newHolderSingleton();
}public staticHolderSingleton getInstance(){returnHolderDemo.instance;
}/*** 测试
*@paramargs*/
public static voidmain(String[] args) {for(int i=0;i<20;i++){new Thread(()->{
System.out.println(HolderSingleton.getInstance());
}).start();
}
}
}
测试结果:
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
com.company.HolderSingleton@616831d4
Process finished with exit code0
其实很想聊聊 static 机制的, 发现自己也是懵懵懂懂,待到以后仔细研究一下在另外写一篇关于 static的文章吧。
之所以说 静态的内部类会在主类调用的时候才会被加载,也是我看别人这没说(很多人也是这没说)。以后真正了解了static 才敢保证正确与否,不过此种方式确实刷新了我的认识