比如双重锁的单例模式
2 回答
扬帆大鱼
TA贡献1799条经验 获得超9个赞
synchronized只保证了代码的有序性,但是变量的赋值操作依旧可以被编译器优化,此时会发生指令重排序;而volatile就是为了防止编译器指令重排序的。具体可以看一下之前这个回答:指令重排序
喵喔喔
TA贡献1735条经验 获得超5个赞
importjava.util.concurrent.locks.Lock;importjava.util.concurrent.locks.ReentrantLock;publicclassSetting{privatestaticSettingsetting;privatestaticLocklock=newReentrantLock();privateSetting(){}publicstaticSettingget(){if(setting!=null){//tag1returnsetting;}lock.lock();if(setting==null){setting=newSetting();}lock.unlock();returnsetting;}}锁只能保证:访问临界区时的原子性,可见性,有序性.然而在tag1那一行,并不是在临界区中,不受锁的保护,因此即使在双重检查时加锁并初始化,也不能保证其他线程能够看到这个初始化后的单例.因此,需要在单例前面加volatile,保证实例的可见性.
添加回答
举报
0/150
提交
取消