【设计模式】单例模式的7种实现方法

一、饿汉式-线程安全

线程安全,但无法实现实例懒加载策略

java 复制代码
/**
 * 饿汉式
 * @author CC
 * @version 1.0
 * @since2023/10/12
 */
public class Singleton {
    private static final Singleton singleton = new Singleton();

    private Singleton() {
    }

    public static Singleton getSingleton() {
        return singleton;
    }
}

二、懒汉式-线程不安全

线程不安全,实现了实例懒加载策略。

java 复制代码
/**
 * 懒汉式
 * @author CC
 * @version 1.0
 * @since2023/10/12
 */
public class Singleton2 {
    private static Singleton2 singleton = null;

    private Singleton2() {
    }

    public static Singleton2 getSingleton() {
        if (singleton == null) {
            singleton = new Singleton2();
        }
        return singleton;
    }
}

三、全局锁式-线程安全

线程安全,实现了懒加载策略,但是线程同步效率不高。

java 复制代码
/**
 * 全局锁
 * @author CC
 * @version 1.0
 * @since2023/10/12
 */
public class Singleton3 {
    private static Singleton3 singleton;

    private Singleton3() {
    }

    public synchronized static Singleton3 getSingleton() {
        if (singleton == null) {
            singleton = new Singleton3();
        }
        return singleton;
    }
}

四、静态代码块式-线程安全

线程安全,类加载时初始化实例,实现了懒加载策略,线程安全。

java 复制代码
/**
 * 静态代码块
 * @author CC
 * @version 1.0
 * @since2023/10/12
 */
public class Singleton4 {
    private final static Singleton4 singleton;

    private Singleton4() {
    }

    static {
        singleton = new Singleton4();
    }

    public static Singleton4 getSingleton() {
        return singleton;
    }
}

五、双重校验锁式-线程安全

线程安全,且实现了懒加载策略,同时保证了线程同步时的效率。

java 复制代码
/**
 * 双重校验锁
 * @author CC
 * @version 1.0
 * @since2023/10/12
 */
public class Singleton5 {
    private  static Singleton5 singleton;

    private Singleton5() {

    }

    public static Singleton5 getSingleton() {
        if (singleton == null) {
            synchronized (Singleton5.class) {
                if (singleton == null) {
                    singleton = new Singleton5();
                }
            }
        }
        return singleton;
    }
}

六、内部类-线程安全

线程安全,不存在线程同步问题,单例对象在程序第一次调用getInstance()时主动加载 SingletonHolder和其 静态成员INSTANCE,因而实现了懒加载策略。推荐使用。

java 复制代码
/**
 * 内部类
 * @author CC
 * @version 1.0
 * @since2023/10/12
 */
public class Singleton6 {
    private Singleton6() {
    }

    private static class Singleton6Holder {
        private static final Singleton6 INSTANCE  = new Singleton6();
    }

    public static Singleton6 getSingleton() {
        return Singleton6Holder.INSTANCE ;
    }
}

七、枚举类-线程安全

线程安全,不存在线程同步问题,且单例对象在枚举类型 INSTANCE第一次引用时通过枚举的 构造函数初始化,从而实现了懒加载策略。推荐使用。

java 复制代码
/**
 * 枚举类
 * @author CC
 * @version 1.0
 * @since2023/10/12
 */
public class Singleton7 {
    private Singleton7() {
    }

    enum SingletonEnum {
        INSTANCE;

        private final Singleton7 singleton;

        private SingletonEnum() {
            singleton = new Singleton7();
        }
    }

    public static Singleton7 getSingleton() {
        return SingletonEnum.INSTANCE.singleton;
    }
}
相关推荐
sino爱学习5 小时前
高性能线程池实践:Dubbo EagerThreadPool 设计与应用
java·后端
风生u6 小时前
activiti7 详解
java
岁岁种桃花儿6 小时前
SpringCloud从入门到上天:Nacos做微服务注册中心(二)
java·spring cloud·微服务
Word码6 小时前
[C++语法] 继承 (用法详解)
java·jvm·c++
TT哇6 小时前
【实习 】银行经理端两个核心功能的开发与修复(银行经理绑定逻辑修复和线下领取扫码功能开发)
java·vue.js
逝水如流年轻往返染尘6 小时前
Java中的数组
java
java1234_小锋6 小时前
Java高频面试题:BIO、NIO、AIO有什么区别?
java·面试·nio
用户8307196840826 小时前
Java IO三大模型(BIO/NIO/AIO)超详细总结
java
sheji34166 小时前
【开题答辩全过程】以 基于SSM的花店销售管理系统为例,包含答辩的问题和答案
java
Mr_sun.7 小时前
Day09——入退管理-入住-2
android·java·开发语言