剑指offer-1单例模式

单例模式所实现的就是只允许这个类生成一个实例

单例模式有两种,分为懒汉式和饿汉式。

饿汉式呢,就是一旦加载该类,不管有没有用到该实例,就先创建出该类的一个唯一实例,这个是天生线程安全的。

public class Singleton1 {

    private Singleton1(){}//私有的构造函数,防止外部调用构造器创建实例
    private static Singleton1 instance = new Singleton1();//静态的唯一实例,因为静态修饰的东西只在类初始化的时候被加载一次
    
    public static Singleton1 getInstance(){
        return instance;
    }
}

懒汉式呢,就是按需创建实例,当需要用到该类实例的时候就去创建,用不到永远也不会去创建。采用了双重校验锁,在多线程环境下也是安全的。

public class Singleton2 {
    private Singleton2(){}
    private static Singleton2 instance = null;//先定义一个空的实例变量
    public static Singleton2 getInstance(){//双重校验锁
        if(instance == null){//第一道屏障是做一个简单的过滤,看是否有创建好的实例,这个在单线程环境下可行,但是多线程环境下就会出问题。
            synchronized(Singleton2.class){//加锁,确保同一时刻只有一个线程执行该部分代码
                /*
                 *第二道屏障,这个是在多线程环境下,如果多个线程越过了第一道屏障, 而且其中已经有一个线程已经获得了锁进入了,
                 *但是还没有创建实例,当这个线程释放锁以后,其他线程抢夺,抢到锁的线程进入再进行判断,发现实例已经被创建,这时候直接返回
                 */
                if(instance == null){
                    instance = new Singleton2();
                }
            }
        }
        return instance;
    }

}

猜你喜欢

转载自www.cnblogs.com/javatalk/p/10091182.html