• 剑指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;
        }
    
    }
  • 相关阅读:
    【BZOJ1076】[SCOI2008]奖励关 状压DP+期望
    【TYVJ1864】[Poetize I]守卫者的挑战 概率与期望
    【BZOJ1426】收集邮票 期望
    设置SAPgui自动退出功能
    SAP系统联机应用程序帮助
    c++ 类型安全
    生成与重新生成的区别
    2014-02-20
    新公司工作
    落后了
  • 原文地址:https://www.cnblogs.com/javatalk/p/10091182.html
Copyright © 2020-2023  润新知