码迷,mamicode.com
首页 > 其他好文 > 详细

单例模式双重检验锁的判断是否为null的意义

时间:2021-05-25 18:05:10      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:判断   single   为什么   singleton   gets   同步   上下文   原因   color   

public class Singleton {
    private volatile static Singleton singleton;
    private Singleton (){}
    public static Singleton getSingleton() {
        if (singleton == null) {
            synchronized (Singleton.class) {
                if (singleton == null) {
                    singleton = new Singleton();
                }
            }
        }
        return singleton;
    }
}

 

双重检验锁是对同步块加锁的方法。为什么会称为双重检验,因为有两次对 instance == null的检查,一次中同步块中一次中同步块外部。

对于两次instance的是否为空的判断解释:

1.为何在synchronization外面的判断?

       为了提高性能!如果拿掉这次的判断那么在行的时候就会直接的运行synchronization,所以这会使每个getInstance()都会得到一个静态内部锁,这样的话锁的获得以及释放的开销(包括上下文切换,内存同步等)都不可避免,降低了效率。所以在synchronization前面再加一次判断是否为空,则会大大降低synchronization块的执行次数。

2.为何在synchronization内部还要执行一次呢?

因为可能会有多个线程一起进入同步块外的 if,如果在同步块内不进行二次检验的话就会生成多个实例了。

 

PS:双重检验情况下,保存实例的唯一的静态变量要用volatile修饰,否则由于线程安全原因,一个类仍然有会生成多个实例。

单例模式双重检验锁的判断是否为null的意义

标签:判断   single   为什么   singleton   gets   同步   上下文   原因   color   

原文地址:https://www.cnblogs.com/wffzk/p/14806882.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!