• 设计模式


    1.【不好的解法】只适用于单线程环境

    缺陷:当两个线程同时执行到 if (instance == null) 时,两个线程均会创建一个实例

    //只适用于单线程环境
    public class Singleton{
        //将无参构造函数私有化,避免外部自行初始化
        private Singleton(){}
        
        //instance设置为static
        private static Singleton instance = null;
        
        //通过getInstance()返回单例
        public static Singleton getInstance(){
            if(instance == null){
                instance = new Singleton();
            }
            return instance;
        }
    }

    2.【不好的解法】多线程能工作,但效率低

    可适用于多线程环境,但无脑加锁导致效率低

    //可适用于多线程环境,但无脑加锁导致效率低
    public class Singleton{
        //将无参构造函数私有化,避免外部自行初始化
        private Singleton(){}
        
        private static final Object syncObj= new Object();
        
        //instance设置为static
        private static Singleton instance = null;
        
        //通过getInstance()返回单例
        public static Singleton getInstance(){
            //解法2: 在一开始就无脑的加锁,损害效率
            synchronized(syncObj){
                if(instance == null){
                    instance = new Singleton();
                }
            }
            return instance;
        }
    }

    3.【可行的解法】多线程环境,同步锁前后两次判断实例是否存在

    可适用于多线程环境,同步锁前后两次判断实例是否存在

    //可适用于多线程环境,同步锁前后两次判断实例是否存在
    public class Singleton{
        //将无参构造函数私有化,避免外部自行初始化
        private Singleton(){}
        
        private static final Object syncObj= new Object();
        
        //instance设置为static
        private static Singleton instance = null;
        
        //通过getInstance()返回单例
        public static Singleton getInstance(){
            //解法3: 只有当instance为null时才加锁; 不为null就不加锁,直接返回...
            if(instance == null){
                synchronized(syncObj){
                    if(instance == null){
                        instance = new Singleton();
                    }
                }
            }
            
            return instance;
        }
    }

    4.【可行的解法】通过静态代码块,更简约

    static代码块加载是在static 变量之后,但是又优先于任何实例化对象创建

    //static代码块
    public class Singleton{
        //将无参构造函数私有化,避免外部自行初始化
        private Singleton(){}
        
        //instance设置为static
        private static Singleton instance = null;
        
        //解法4: static代码块加载是在static 变量之后,但是又优先于任何实例化对象创建
        static{
            instance = new Singleton();
        }
        
        //通过getInstance()返回单例
        public static Singleton getInstance(){
            return instance;
        }
    }
  • 相关阅读:
    异常
    vue子组件修改父组件vmodal传递回来的值 义美
    EXT2fs (ram0): error: ext2_get_inode: unable to read inode block inode=24582, block=98339
    软中断
    Xenomai source code analysis Chapter 1 xenomai_init
    Linux 内核源码分析之进程调度的逻辑
    Stopping at filesystem boundary (GIT_DISCOVERY_ACROSS_FILESYSTEM not set).
    mkintramfs mkinitrd initrd.img
    /lib/libgcc_s.so.1: version `GCC_3.5'
    alpine
  • 原文地址:https://www.cnblogs.com/frankcui/p/14282345.html
Copyright © 2020-2023  润新知