你真的了解单例模式吗?你真的认为单例模式很简单吗? 第一篇

你正在写的单例模式,也许并不像你想的那样安全。
单例模式算是设计模式中最为容易理解,也是最容易实现的一种模式。很多人经常会说单例模式那么简单,为什么面试的时候还要考?简单?你的单例在
多线程环境下真的安全吗?双检索知道是什么吗?
哦,对了,也许你常见的和常用的就是这种写法:

public class SingleFactory {

    private static SingleFactory instance;

    private SingleFactory() {
    }

    public static SingleFactory getInstance() {
        if (instance == null) {
            instance = new SingleFactory();
        }
        return instance;
    }

}

嗯,看起来确实是那么回事,反正static全局只有一个嘛,永远都会是那一个呀!
呵呵,too young too simple!
上段最垃圾的多线程代码,你就知道自己有多么可悲(你被多少教科书或是老师给骗了)

public class Main {

    public static void main(String[] args) {
        
        Thread t1 = new Thread(new Runnable() {
            
            public void run() {
                System.out.println(SingleFactory.getInstance().hashCode());
            }
        });
        Thread t2 = new Thread(new Runnable() {
            
            public void run() {
                System.out.println(SingleFactory.getInstance().hashCode());
            }
        });
        Thread t3 = new Thread(new Runnable() {
            
            public void run() {
                System.out.println(SingleFactory.getInstance().hashCode());
            }
        });
        Thread t4 = new Thread(new Runnable() {
            
            public void run() {
                System.out.println(SingleFactory.getInstance().hashCode());
            }
        });
        
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        
    }
    
}

也许你的可能输出结果一样,但是请多试几次,但至少我的是这样:
18064701
18064701
2814081
18064701
hashCode证明一切。
(有过被欺骗经历的小伙或小姑娘可以去找骗你的那个人拼命了,只要不说是赵哥让你们去的就好。)

 

知客
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单例模式是一种设计模式,它保证一个类只有一个实例,并提供全局访问点。 双重检验锁(Double Check Lock)方式是一种在多线程环境下实现单例模式的方式。其核心思想是在第一次调用时才创建对象,如果已经创建过对象则直接返回该对象。具体实现如下: 1. 私有化构造函数,防止外部直接创建对象。 2. 声明一个静态变量,用来保存单例对象。 3. 提供一个公共的静态方法,用来获取单例对象。 4. 在公共方法中,先判断单例对象是否已经被创建,如果没有则进行加锁,然后再次判断单例对象是否已经被创建,如果还没有则创建单例对象,最后释放锁。 以下是双重检验锁方式实现单例模式的代码示例: ``` public class Singleton { 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; // 返回单例对象 } } ``` 需要注意的是,在第一重检验时,因为存在多线程并发访问的情况,可能会出现多个线程同时判断单例对象为null的情况,从而同时进入加锁的代码块。因此需要使用volatile关键字来保证instance变量在多线程环境下的可见性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值