java单例模式

本文详细探讨了Java中的volatile关键字如何防止指令重排序,以及在实现单例模式时如何配合双重检查锁定(Double-Check Locking)避免线程安全问题。介绍了一种基于静态内部类的单例模式,它利用类加载机制确保线程安全。
摘要由CSDN通过智能技术生成
public class Singleton {
    //volatile保证jvm不重排序
    private static volatile Singleton instance;

    private Singleton(){}

    public static Singleton getInstance() {
        if (instance == null) {//双重检验
            synchronized (Singleton.class) {
                if (instance == null) {
                    instance=new Singleton();
                }
            }
        }
        return instance;
    }

}

当执行instance=new Singleton();时,jvm中分为三步

  1. 分配内存空间
  2. 初始化对象
  3. 将内存地址赋值给引用

但是执行这条语句的时候很可能顺序为1.3.2,这就会导致后面进来的进行虽拿到了锁,并且爷判断了instance不为null,取到的instance很可能为未初始化的对象。所以我们需要在对象成员前面加上volatile关键之来防止jvm指令重排

指令重排序(Instruction Reorder):一般来说,处理器为了提高程序运行效率,可能会对输入代码进行优化,它不保证程序中各个语句的执行先后顺序同代码中的顺序一致,但是它会保证程序最终执行结果和代码顺序执行的结果是一致的。

下面展示另外一种单例模式的写法

public class SingletonStatic {
    private static class SingletonHolder{
        public static final SingletonStatic INSTANCE = new SingletonStatic();
    }

    public SingletonStatic getInstance() {
        return SingletonHolder.INSTANCE;
    }
}

通过静态类来实现单例,是在classloader层面上实现的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值