多线程核心技术-单例模式

单例模式在设计模式中比较常见,在多线程访问的时候容易出现线程不安全的隐患

懒汉式(延迟加载)/饿汉式(立即加载)

直接给出双检查锁单例模式

public class Singleton {   
     private static Singleton instance;   
     private Singleton (){ 
     }    
     public static Singleton getInstance(){    
       if (instance == null){ 
           synchronized(Singleton.class){ 
               if (instance == null) 
                   instance = new Singleton();  
           } 
       } 
       return instance; 
     } 
    
 } 

问题根源在此: new对象可拆分成3个指令执行
                     1、memory = allocate() //分配内存
                     2、ctorInstance(memory) //初始化对象
                     3、instance = memory //instance指向刚分配的内存地址
其中2和3可能会指令重排,如果发生指令重排,先执行了指令3,此时线程2执行第一个if判断时就是false,此时直接返回一个没有初始化的instance对象,导致系统错误
所以应加上volatile禁止重排序
public class Singleton {   
     private volatile static Singleton instance;   
     private Singleton (){ 
     }    
     public static Singleton getInstance(){    
       if (instance == null){ 
           synchronized(Singleton.class){ 
               if (instance == null) 
                   instance = new Singleton();  
           } 
       } 
       return instance; 
     } 
    
 }


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值