JAVA单例实现(双重检查懒加载和静态内部内加载)

本文探讨了Java中实现单例模式的两种方法:双重检查懒加载和静态内部类加载。双重检查懒加载在确保线程安全的同时延迟初始化,防止空指针异常。静态内部类加载利用类加载机制保证单例的唯一性,同时避免了同步带来的性能影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

双重检查懒加载

双重检查懒加载需要控制单例的可见性,多线程情况下可能出现空指针问题


/**
 * 双重检查单例模式
 */
public class DoubleCheckSingleton {
    //未使用volatile 可能在初始化的时候出现内存屏障内的指令重排,
    // 导致后续线程读取到第一个判断时候获取到初始化的值,而不是单例的值
//    private static  DoubleCheckSingleton singleton;
    /**
     * 修改版本保证单例的可见性和指令重排的可能新性
     */
    private static volatile DoubleCheckSingleton singleton;

    private DoubleCheckSingleton(){}

    public static DoubleCheckSingleton getInstance(){
        if(null == singleton){
            //初始化
            synchronized (DoubleCheckSingleton.class){
                if(null == singleton){
                    singleton = new DoubleCheckSingleton();
                }
            }
        }
        return singleton;
    }

}

静态内部内加载


/**
 * 静态内部类实现单例模式
 */
public class StaticInnerClassSingleton {

    private StaticInnerClassSingleton(){}

    private static class InstanceHolder{

        final static StaticInnerClassSingleton SINGLETON = new StaticInnerClassSingleton();
    }

    public static StaticInnerClassSingleton getInstance(){
        return InstanceHolder.SINGLETON;
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值