zoukankan      html  css  js  c++  java
  • 单例模式——5种实现方式

    单例模式能够保证一个类仅有唯一的实例,并提供一个全局访问点。

    1、饿汉式(线程安全,调用效率高,但是不能延时加载):

    public class Singleton {
    // 使用final修饰是防止被继承
    private static final Singleton singleton= new Singleton();
    private Singleton(){

    }
    public static Singleton getInstance(){
    return singleton;
    }
    }
    2.懒汉式(线程安全,调用效率不高,但是能延时加载):
    public class SingletonDemo2 {
         
        //类初始化时,不初始化这个对象(延时加载,真正用的时候再创建)
        private static SingletonDemo2 instance;
         
        //构造器私有化
        private SingletonDemo2(){}
         
        //方法同步,调用效率低
        public static synchronized SingletonDemo2 getInstance(){
            if(instance==null){
                instance=new SingletonDemo2();
            }
            return instance;
        }
    }
    3.Double CheckLock实现单例:DCL也就是双重锁判断机制(线程不安全,调用效率高,延时加载。由于JVM底层模型原因,偶尔会出问题,不建议使用):

    public class SingletonDemo5 {
    private volatile static SingletonDemo5 SingletonDemo5;

    private SingletonDemo5() {
    }

    public static SingletonDemo5 newInstance() {
    if (SingletonDemo5 == null) {
    synchronized (SingletonDemo5.class) {
    if (SingletonDemo5 == null) {
    SingletonDemo5 = new SingletonDemo5();
    }
    }
    }
    return SingletonDemo5;
    }
    }

    4.静态内部类实现模式(线程安全,调用效率高,可以延时加载)

    public class SingletonDemo3 {

    private static class SingletonClassInstance{
    private static final SingletonDemo3 instance=new SingletonDemo3();
    }

    private SingletonDemo3(){}

    public static SingletonDemo3 getInstance(){
    return SingletonClassInstance.instance;
    }

    }

    5.枚举类(线程安全,调用效率高,不能延时加载,可以天然的防止反射和反序列化调用)

    public enum SingletonDemo4 {

    //枚举元素本身就是单例
    INSTANCE;

    //添加自己需要的操作
    public void singletonOperation(){
    }
    }

    如何选用:

    -单例对象 占用资源少,不需要延时加载,枚举 好于 饿汉

    -单例对象 占用资源多,需要延时加载,静态内部类 好于 懒汉式

  • 相关阅读:
    27数据结构与算法分析之---二叉排序树
    26数据结构与算法分析之---线索二叉树
    25数据结构与算法分析之---树与森林
    24数据结构与算法分析之---二叉树的概念
    23数据结构与算法分析之---树的基本概念
    22数据结构与算法分析之---特殊矩阵
    21数据结构与算法分析之---多维数组
    20数据结构与算法分析之---串的模式匹配
    17数据结构与算法分析之---串的类型
    16数据结构与算法分析之---链式队列
  • 原文地址:https://www.cnblogs.com/cn-chy-com/p/11171879.html
Copyright © 2011-2022 走看看