单例设计模式---懒汉式--线程安全和不安全、枚举类

单例设计模式---懒汉式--线程安全和不安全

优点

资源利用率高:只有在真正需要使用单例实例时才进行创建,避免了在应用启动时就占用不必要的资源。

缺点

线程安全问题:在多线程环境下,如果多个线程同时调用获取实例的方法,可能会导致创建多个实例,破坏单例模式的规则。需要额外的同步机制来保证线程安全,但这可能会带来一定的性能开销。

线程不安全

java 复制代码
//懒汉式 线程不安全
public class Singleton {
    //私有构造方法
    private Singleton(){}
    //声明Singleton类型的变量instance
    private static Singleton instance;//只是声明了该类型的变量,并没有创建
    //对外提供访问方式
    public static Singleton getInstance(){
        //判断instance是否为null,如果为null,说明还没有创建Singleton类的对象
        //如果没有创建一个并返回。如果有,直接返回
        if(instance == null){
            //线程1等待,线程2获取到cpu的执行权,也会进入到该判断里面
            //多线程执行时,只要线程停留在这里,其他线程就可以进入,那么就不是单实例模式
            instance = new Singleton();
        }
        instance=new Singleton();
        return instance;
    }
}

public class Client {
    public static void main(String[] args) {
        Singleton instance =Singleton.getInstance();
        Singleton instance1 =Singleton.getInstance();
        //判断两次获取到的Singleton对象是否是同一个对象
        System.out.println(instance==instance1);
    }
}

线程安全

java 复制代码
//线程安全,依据以上线程不安全做修改
public class Singleton {
    //私有构造方法
    private Singleton(){}
    //声明Singleton类型的变量instance
    private static Singleton instance;//只是声明了该类型的变量,并没有创建
    //对外提供访问方式
    public static synchronized Singleton getInstance(){
       
        if(instance == null){
            instance = new Singleton();
        }
        instance=new Singleton();
        return instance;
    }
}

枚举类

饿汉式枚举类是实现单例模式的一种高效且安全的方式。

枚举类型在 Java 中是一种特殊的类,它的实例是有限且固定的。当使用枚举类实现单例模式时,枚举类的实例在类加载时就会被创建,并且是唯一的,这符合饿汉式单例的特点,即在类加载时就初始化单例实例。同时,Java 语言规范保证了枚举类型的实例是线程安全的,并且可以防止反射攻击和反序列化时创建新的实例。

java 复制代码
package patten.demo6;
//饿汉式 枚举类
public enum Singleton {
    INSTANCE;
}

枚举类测试

java 复制代码
public class Client {
    public static void main(String[] args) {
        Singleton instance = Singleton.INSTANCE;
        Singleton instance1 = Singleton.INSTANCE;
        //判断两次获取到的Singleton对象是否是同一个对象
        System.out.println(instance==instance1);
    }

}
相关推荐
wengqidaifeng22 分钟前
2. OpenClaw 架构落地指南:部署、渠道集成与安全边界全解
安全·ai·架构·openclaw
lqqjuly35 分钟前
设计模式:理论、架构与 C++ 实现—SOLID原则到23 种经典模式
c++·设计模式·架构
网络研究院2 小时前
即将过期的安全启动证书将如何影响 Windows 设备
安全·微软·系统·漏洞·硬件
志栋智能2 小时前
超自动化安全:构建智能安全运营的神经系统
大数据·运维·网络·人工智能·安全·自动化
无风听海2 小时前
Bearer Token 权威指南:从原理到生产级安全实践
前端·javascript·安全
EasyDSS2 小时前
安全可控、全场景适配:私有化音视频系统/视频直播点播EasyDSS一站式云平台重构视频协作新模式
安全·重构·音视频
黎阳之光3 小时前
无感定位·智管全域:黎阳之光人员无感定位管理系统,重新定义安全与效率
人工智能·物联网·算法·安全·数字孪生
牛奶3 小时前
黑客是怎么看到你数据的?
前端·安全·黑客
网络研究院3 小时前
管理瘫痪、人员短缺:深度解析 NIST NVD 为什么审不动漏洞了?
网络·安全·漏洞·管理·危机
上海云盾安全满满4 小时前
为什么访问不一样的网站会有快有慢?
网络·安全