【设计模式】单例模式的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;
    }
}
相关推荐
NE_STOP3 小时前
MyBatis-plus进阶之映射与条件构造器
java
Seven975 小时前
NIO的零拷贝如何实现高效数据传输?
java
架构师沉默20 小时前
别又牛逼了!AI 写 Java 代码真的行吗?
java·后端·架构
后端AI实验室1 天前
我把一个生产Bug的排查过程,交给AI处理——20分钟后我关掉了它
java·ai
凉年技术1 天前
Java 实现企业微信扫码登录
java·企业微信
狂奔小菜鸡1 天前
Day41 | Java中的锁分类
java·后端·java ee
hooknum1 天前
学习记录:基于JWT简单实现登录认证功能-demo
java
程序员Terry1 天前
同事被深拷贝坑了3小时,我教他原型模式的正确打开方式
java·设计模式
NE_STOP1 天前
MyBatis-缓存与注解式开发
java
码路飞1 天前
不装 OpenClaw,我用 30 行 Python 搞了个 QQ AI 机器人
java