三种单例模式

三种单例

public class Singleton {
//  三种单例模式
  /* 饿汉式  线程安全
  private static Singleton instance = new Singleton();
  private Singleton(){}
  public static Singleton getInstance(){
    return instance;
  }
   */

  //懒汉式  线程不安全
//  private static Singleton instance;
//  private Singleton(){}
//  public static Singleton getInstance() {
//    if(instance == null){
//      instance = new Singleton();
//    }
//    return instance;
//  }

//  双检锁
private static volatile Singleton instance;
private Singleton(){}
//public static synchronized Singleton getInstance(){
//  if(instance == null){
//    instance = new Singleton();
//  }
//  return instance;
//}
  //上面写法的不足是:效率过低,每次进入方法都要加锁,成本很高(包含moniter的进入和阻塞时的上下文切换)
  //显然我们只是需要在重建的时候进行同步操作(也就是写的时候),其他时候都是直接读取的,不需要同步。这就是典型写少读多了,
// 这时我们就要考虑到可见性的问题,每个线程都有自己的缓存区,修改共享变量也是在自己的缓冲区,这就可能出问题,这不volatile他来了。
public static Singleton getInstance(){
  if(instance == null){
    synchronized (Singleton.class){
      if(instance == null){
        instance = new Singleton();
      }
      return instance;
    }
  }
  return instance;

}
  public static void main(String[] args) {
//    Singleton test1 = getInstance();
//    Singleton test2 = getInstance();
//    System.out.println(test1.equals(test2));
    for(int i = 0;i<1000;i++){
      new Thread(()->{
        for(int j = 0;j<10;j++){
          Singleton test = getInstance();
          System.out.println(System.identityHashCode(test));
        }
      },"线程"+i).start();
    }
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值