单例模式-懒汉式的一次多线程Debug

单例模式要要点就是一个类只会存在一个实例,要想达到这种效果,最重要的就是将构造方法设置为私有,然后通过static的方法来获取对象。

单例模式-懒汉式的一次多线程Debug

上述设计并不线程安全,因为在lazySingleton = new LazySingletion()这一步可能会发送线程的切换,导致出现多个lazySingletion对象。

可以通过多线程Debug来测试。

线程类:

单例模式-懒汉式的一次多线程Debug

测试类:

单例模式-懒汉式的一次多线程Debug

在多线程Debug时需要在断点处勾选Thread

 单例模式-懒汉式的一次多线程Debug

之后开始Debug。

单例模式-懒汉式的一次多线程Debug

开始时创建了两个LazyThread线程对象。

单例模式-懒汉式的一次多线程Debug

可以看到目前有三个进程,Main,Thread-0,Thread-1

我们切换至Thread-0将此线程执行到LazySingleton对象创建处。

单例模式-懒汉式的一次多线程Debug

此时lazySingleton还没有实例化,为null,所以Thread-1也可以通过if判断进入其中。我们将Thread-1线程也执行至此处。

单例模式-懒汉式的一次多线程Debug

接下来的顺序就无所谓了,两个线程都会去自己实例化lazySingleton对象。

 单例模式-懒汉式的一次多线程Debug

执行完成后通过打印发现lazySingleton对象其实不是同一个。

如果我们正常运行呢?

单例模式-懒汉式的一次多线程Debug

可以发现大部分情况下都会时同一个lazySingleton对象。

为了保证线程安全性,可以通过synchronized来修饰getInstance方法。

至于这种情况下的调试,在Thread-0进入synchronized块中时,切换至Thread-1会发现无法进入。

posted @ 2019-03-17 19:39 AntzUhl 阅读(...) 评论(...) 编辑 收藏

相关文章:

  • 2022-12-23
  • 2022-03-10
  • 2022-01-18
  • 2022-02-22
  • 2022-02-21
  • 2022-12-23
  • 2022-12-23
  • 2021-04-17
猜你喜欢
  • 2021-06-09
  • 2022-12-23
  • 2021-08-27
  • 2022-12-23
  • 2021-06-29
  • 2022-12-23
  • 2021-08-23
相关资源
相似解决方案