2_单列模式_懒汉式单例模式

二.懒汉式单例模式

(1) 饿汉式单例模式概念

为了解决饿汉式单例可能带来的内存浪费问题,于是就出现了懒汉式单例的写法。懒汉式单例模式的特点是,单例对象要在被使用时才会初始化。

(2) 代码实现

实现代码方式1:简单的饿汉式单例

java 复制代码
/**
 * 优点:节省了内存,线程安全
 * 缺点:性能低,反射破坏,序列化破坏单例 (当有1万线程访问的时候,都会排队等待每个线程执行完才进行下一个线程执行。因为添加了synchronized锁)
 */
public class LazySimpleSingletion {
    private static LazySimpleSingletion instance;
    private LazySimpleSingletion(){}
    public synchronized static LazySimpleSingletion getInstance(){
        if(instance == null){
            instance = new LazySimpleSingletion();
        }
        return instance;
    }
}

实现代码方式2:添加双重检查

java 复制代码
/**
 * 优点:性能高了,线程安全了
 * 缺点:可读性难度加大,不够优雅, 反射破坏, 序列化破坏单例
 */
public class LazyDoubleCheckSingleton {
    private volatile static LazyDoubleCheckSingleton instance;
    private LazyDoubleCheckSingleton(){}
    public static LazyDoubleCheckSingleton getInstance(){
        //检查是否要阻塞
        if (instance == null) {
            synchronized (LazyDoubleCheckSingleton.class) {
                //检查是否要重新创建实例
                if (instance == null) {
                    instance = new LazyDoubleCheckSingleton();
                    //指令重排序的问题,需要加volatile关键字线程可见性。
                }
            }
        }
        return instance;
    }
}

实现代码方式3:静态类内部类实现

java 复制代码
/*
   优点:写法优雅,利用了Java本身语法特点,性能高,避免了内存浪费,不能被反射破坏
   缺点:可读性难度加大,不优雅,序列化破坏单例
 */
public class LazyStaticInnerClassSingleton {
    private LazyStaticInnerClassSingleton(){
        if(LazyHolder.INSTANCE != null){
            throw new RuntimeException("不允许非法访问");
        }
    }
    private static LazyStaticInnerClassSingleton getInstance(){
        return LazyHolder.INSTANCE;
    }
    private static class LazyHolder{
        private static final LazyStaticInnerClassSingleton INSTANCE = new LazyStaticInnerClassSingleton();
    }
}

(3)使用场景

懒汉式单例模式的特点是,单例对象要在被使用时才会初始化。

当项目中出现大量单列对象时候,这个样就会节省内存空间。

(4)有缺点

优点:节省了内存,线程安全

缺点:性能低,反射破坏,序列化破坏单例 (当有1万线程访问的时候,都会排队等待每个线程执行完才进行下一个线程执行。因为添加了synchronized锁)


优点:性能高了,线程安全了

缺点:可读性难度加大,不够优雅, 反射破坏, 序列化破坏单例


优点:写法优雅,利用了Java本身语法特点,性能高,避免了内存浪费,不能被反射破坏

缺点:可读性难度加大,不优雅,序列化破坏单例

相关推荐
许彰午9 小时前
34_Java设计模式之单例模式
java·单例模式·设计模式
罗超驿2 天前
10.Java单例模式全解析:饿汉式与懒汉式实现及线程安全深度剖析
安全·单例模式·javaee
布朗克1682 天前
33 设计模式精讲
java·单例模式·设计模式
雨浓YN2 天前
基于设计模式的Winform软件框架-01Xml\Log\Ini日志(单例模式+生产者消费者模式)
单例模式·设计模式
仙俊红3 天前
Java 单例模式:类里面为什么可以有自己类型的字段?
java·开发语言·单例模式
swordbob3 天前
prototype 注入到 singleton 里,prototype是否还是线程安全的
安全·spring·单例模式·原型模式
谁似人间西林客5 天前
工业大数据实战:看中国智造如何用数据驱动效率革命
大数据·单例模式
张小姐的猫5 天前
【Linux】多线程 —— 线程池 | 单例模式 | 常见锁
linux·运维·服务器·c++·单例模式·设计模式·策略模式
Java面试题总结6 天前
双重检验锁的单例模式在高并发下的可见性问题
单例模式
珊瑚里的鱼9 天前
手撕单例模式中的饿汉模式和懒汉模式,懒汉模式还要再多加一个C++11版本的
开发语言·c++·单例模式