代码
public class SingleBean {
private static volatile SingleBean instance = null;
private SingleBean () {
}
public static SingleBean getInstance() {
if (instance == null) {
synchronized(SingleBean.class) {
if (instance == null) {
instance == new SingleBean();
}
}
}
return instance;
}
}
还不太理解的朋友可以先看看这篇文章 volatile原理
instance 为什么使用 volatile 修饰。
试想场景:当多个线程同时进入到 synchroized 处。
倘若不加 volatile 关键字。
线程 A 得到锁,并执行了构造函数。
线程 B 得到锁,在第二次判断 instance == null 时,因为拿到的值是之前的拷贝,没有从 主存 中拿到最新的值,此时该语句结果为 true,会再次将 instance 实例化一次。