关于java多线程下单例模式的写法与理解

这两天对java并发的内容进行了一个学习,主要是对synchronized和volatile这两个关键字做了更深入的学习。由此想到怎样创建线程安全的单例模式,网上有很多,写下来是加深自己的理解!!!

package com.ab.adou.thread;

/**
* @author ASUS
* 多线程情况下 安全的线程模式
* double click check 双检查锁机制
*/
public class SafeThreadSingleton {
private volatile static SafeThreadSingleton instance ;

private SafeThreadSingleton(){}

public static SafeThreadSingleton getInstance(){
    if (instance == null) {
        synchronized (SafeThreadSingleton.class) {//加锁 防止同时有多个线程进入 并new对象
            if(instance == null){//这里加一重判断 是防止在外面等待锁的线程 又去new对象
                instance = new SafeThreadSingleton();
            }
        }
    }
    return instance;
}

}

—————————————这里是华丽的分割线————————————-

package com.ab.adou.thread;
public class MyCheckThread extends Thread{

@Override  
public void run() {   
    System.out.println(SafeThreadSingleton.getInstance().hashCode());  
}  

public static void main(String[] args) {   

    MyCheckThread[] mts = new MyCheckThread[100];  
    for(int i = 0 ; i < mts.length ; i++){  
        mts[i] = new MyCheckThread();  
    }  

    for (int j = 0; j < mts.length; j++) {  
        mts[j].start();  
    }  
}  

}

主要是想说明一下 为什么要进行第二次的instance == null判断,因为synchronized是把锁加在了类class上,有可能有多个线程在等待第一个获取锁的线程创建完实例后释放锁,如果不进行二次判断,这些等待锁的线程又会继续创建出新的实例来,违背我们的初衷。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值