静态内部类与双重检查实现单例模式
静态内部类实现单例模式
//静态内部类实现单例模式
public class SingleTon07 {
private SingleTon07() {}
private static class SingleToninstance{
private static final SingleTon07 INSTANCE_TON07=new SingleTon07();
}
public SingleTon07 getinstanceTon07() {
return SingleToninstance.INSTANCE_TON07;
}
/* 优缺点说明:
1) 这种方式采用了类装载的机制来保证初始化实例时只一个线程。
2) 静态内部类方式在Singleton类被装载时并不会立即实例化,而是在需要实例化
时,调用getInstance方法,才会装载SingletonInstance类,从而完成Singleton的
实例化。
3) 类的静态属性只会在第一次加载类的时候初始化,所以在这里,JVM帮助我们
保证了线程的安全性,在类进行初始化时,别的线程是无法进入的。
4) 优点:避免了线程不安全,利用静态内部类特点实现延迟加载,效率高
5) 结论:推荐使用
*
*/
}
双重检查实现单例模式
//双重检查实现单例模式
public class SingleTon06 {
private static SingleTon06 instanceTon06;
private SingleTon06(){}
public static SingleTon06 getinstanceTon06() {
if (instanceTon06== null) {
synchronized (SingleTon06.class) {
if (instanceTon06==null) {
instanceTon06=new SingleTon06();
}
}
}
return instanceTon06;
}
/*
- 优缺点说明:
- Double-Check概念是多线程开发中常使用到的,如代码中所示,我们进行了两
次if (singleton == null)检查,这样就可以保证线程安全了。 - 这样,实例化代码只用执行一次,后面再次访问时,判断if (singleton == null),
直接return实例化对象,也避免的反复进行方法同步. - 线程安全;延迟加载;效率较高
- 结论:在实际开发中,推荐使用这种单例设计模式
*/
}
- Double-Check概念是多线程开发中常使用到的,如代码中所示,我们进行了两

浙公网安备 33010602011771号