懒汉模式
1.加入第一重锁,有可能线程1和线程2都执行到判断空的方法,new会被执行两次
2.1锁也可以加在第一个判断空的方法上,但是该方法调用频繁,将会导致程序执行性能的下降。
2.2加入锁之后,也会有同样的问题,线程1拿到锁执行,实例化对象;线程2阻塞,当线程1执行完线程2拿到锁后,依然会实例化对象
3.双重检查锁
思考:是否需要加volatile
实例化的时候,执行顺序可以是
也可以是
如果线程1,执行了1,3,这时候构造方法还没有给i赋值13,还是默认的0
线程2判断对象不为空,直接拿着对象.属性拿到的是默认值0,所以需要加volatile保证代码的执行有序性
最终版
public class SingletonDemo4 {
private static volatile SingletonDemo4 singletonDemo4;
private SingletonDemo4 (){}
public static SingletonDemo4 getSingletonDemo1(){
if(singletonDemo4==null){//第一重检查
synchronized (SingletonDemo4.class){ //加锁
try { TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) { e.printStackTrace(); }
if(singletonDemo4==null){//第二重检查
singletonDemo4=new SingletonDemo4();
}
}
}
return singletonDemo4;
}
public static void main (String[] args) {
for (int i = 0; i < 50; i++) {
new Thread(()->{
System.out.println(SingletonDemo4.getSingletonDemo1().hashCode());
}).start();
}
}
}
来源:https://www.bilibili.com/video/BV1zy4y1q7h4?from=search&seid=4118757941413943431