• Java设计模式之单例模式(七种写法)


    Java设计模式之单例模式(七种写法)

    第一种,懒汉式,lazy初始化,线程不安全,多线程中无法工作:

    public class Singleton {
        private static Singleton instance;
        private Singleton (){}//私有化构造方法,防止类被实例化
        public static Singleton getInstance() {
        if (instance == null) {
            instance = new Singleton();
        }
        return instance;
        }
    }

    第二种,懒汉式,lazy初始化,线程安全:

    • 优点:第一次调用才初始化,避免内存浪费。
    • 缺点:必须加锁 synchronized 才能保证单例,但加锁会影响效率。
    public class Singleton {
        private static Singleton instance;  
        private Singleton (){}  
        public static synchronized Singleton getInstance() {  
        if (instance == null) {  
            instance = new Singleton();  
        }  
        return instance;  
        }  
    }  
    第三种,饿汉式,不是lazy初始化,线程安全:
    • 优点:没有加锁,执行效率会提高。
    • 缺点:类加载时就初始化,浪费内存。
    public class Singleton {  
        private static Singleton instance = new Singleton();  
        private Singleton (){}  
        public static Singleton getInstance() {  
            return instance;
        }  
    } 

    第四种,饿汉式,lazy初始化,线程安全:

    public class Singleton {
        private Singleton instance = null;  
        static {  
            instance = new Singleton();
        }  
        private Singleton (){}  
        public static Singleton getInstance() {  
            return this.instance;
        }  
    }  
    第五种,静态内部类,lazy初始化,线程安全:

    区别第三种,Singleton 类被装载了,instance 不一定被初始化。因为 SingletonHolder 类没有被主动使用;只有通过显式调用 getInstance 方法时,才会显式装载 SingletonHolder 类,从而实例化 instance。
    public class Singleton {
        private static class SingletonHolder {  
            private static final Singleton INSTANCE = new Singleton();
        }  
        private Singleton (){}  
        public static final Singleton getInstance() {  
            return SingletonHolder.INSTANCE;
        }  
    }  

    第六种(枚举),不是lazy初始化,线程安全:

    public enum Singleton {
        INSTANCE;  
        public void whateverMethod() {  
        }  
    } 
    第七种,双重校验锁DCL(double-checked locking),lazy初始化,线程安全:

    JDK1.5 起,采用双锁机制,安全且在多线程情况下能保持高性能。
    public class Singleton {
        private volatile static Singleton singleton;  
        private Singleton (){}  
        public static Singleton getSingleton() {  
            if (singleton == null) {
                synchronized (Singleton.class) {
                if (singleton == null) {
                    singleton = new Singleton();
                    }
                }
            }
            return singleton;
        }  
    }  
    
    
  • 相关阅读:
    vuesocket.io在单文件中使用(进入到单文件再发请求)
    el-tree设置默认展开及选中
    Vue项目中解决跨域问题
    echarts堆叠条形图计算总数()
    原生js实现点击目标区域外侧触发事件
    js构造树形菜单
    wangEditor服务器上传图片(Vue使用)
    webpack(6) 打包多页应用和sourcemap 使用
    NoSql相关
    Markdown
  • 原文地址:https://www.cnblogs.com/shen-hua/p/8179046.html
Copyright © 2020-2023  润新知