设计模式 - 创建型模式 - 单例模式

饿汉模式

类加载时创建对象【常量】

class EagerSingleton {
    private static final EagerSingleton instance = new EagerSingleton();
    private EagerSingleton() {
    }
    public static EagerSingleton getInstance() {
        return instance;
    }
}

懒汉模式

  延迟加载;
  假如在某一瞬间”线程A”和”线程B”都在调用getInstance()方法,此时instance对象为null值,均能通过instance == null的判断。
  由于实现了synchronized加锁机制,”线程A”进入synchronized锁定的代码中执行实例创建代码,”线程B”处于排队等待状态,必须等待”线程A”执行完毕后才可以进入synchronized锁定代码。
  但当”线程A”执行完毕时,”线程B”并不知道实例已经创建,将继续创建新的实例,导致产生多个单例对象,违背单例模式的设计思想,因此需要进行进一步改进,在synchronized中再进行一次instance == null判断,这种方式称为 双重检查锁定(Double-Check Locking)。

class LazySingleton {
    private volatile static LazySingleton instance = null;

    private LazySingleton() {
    }

    public static LazySingleton getInstance() {
        //第一重判断
        if (instance == null) {
            //锁定代码块
            synchronized (LazySingleton.class) {
                //第二重判断
                if (instance == null) {
                    instance = new LazySingleton(); //创建单例实例
                }
            }
        }
        return instance;
    }
}  

IoDH

延迟加载且不需要进行线程安全控制

//Initialization on Demand Holder
class Singleton {
    private Singleton() {
    }
    private static class HolderClass {
        private final static Singleton instance = new Singleton();
    }
    public static Singleton getInstance() {
        return HolderClass.instance;
    }
    public static void main(String args[]) {
        Singleton s1, s2;
        s1 = Singleton.getInstance();
        s2 = Singleton.getInstance();
        System.out.println(s1 == s2);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值