单例模式---线程安全的懒汉模式(双重检测)

本文深入解析单例模式,包括饿汉式与线程安全的懒汉式实现。探讨构造方法私有化、类内部对象创建及静态方法获取实例的过程。特别关注线程安全的懒汉式单例模式中双重检测机制与volatile关键字的作用。

饿汉式单例模式以及线程不安全的懒汉式的单例模式,之前的博客链接:https://mp.youkuaiyun.com/postedit/86522796

单例模式:一个类只允许产生一个对象
一般步骤:

  • 构造方法私有化
  • 类的内部new出对象
  • 通过静态方法get得到该类的唯一实例化对象

class SingLeton {
    private static volatile SingLeton singLeton = null;
    //构造方法私有化,类的外部不能实例化对象
    private SingLeton() {}
    //类的静态方法获取类的唯一对象
    public static SingLeton getSingLeton() {
        if(null == singLeton) {                 
            synchronized(SingLeton.class) {                
                if(null == singLeton) {                
                    //类的内部new出唯一的实例化对象
                    singLeton = new SingLeton();        
                }
            }
        }
        return singLeton;
    }
}

线程安全的懒汉式单例模式,使用双重检测方式,保证了在多线程访问的情况下,只实例化一个对象。
说一下volatile关键字,有两个作用

  • 保证可见性
  • 防止指令重排
    此处使用volatile是为了防止在多线程访问时,访问到没有完全初始化的对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值