Java内存模型的抽象示意图:
基础巩固之图解Java内存模型

在Java中,所有的对象域静态域以及数组元素都存放在堆内存中,堆内存在各个线程之间共享,为主内存。
从上图看,线程A如果要和线程B之间要通信的话,要经过如下几个步骤:

  • 线程A先将本地工作内存A中变更过的变量更新到主内存中去。
  • 线程B到主内存中去读取线程A之前更新过的共享变量

基础巩固之图解Java内存模型

  • 本地内存A本地内存B有主内存中的共享变量x的副本,当线程A执行完毕后,更新x的值为1,临时存放在自己的本地内存中,线程A线程B需要通信的时候,线程A首先会把自己本地内存中修改后的x值更新到主内存中,此时主内存中的x值变为1了,随后,线程B到主内存中读取线程A更新后的x值,此时线程B的本地内存x值也就变为1了

小结:
由上图可知:线程间的通信过程必须要经过主内存。

参考:
《Java并发编程的艺术》

相关文章:

  • 2021-11-04
  • 2021-10-16
  • 2022-02-06
  • 2021-09-30
  • 2021-07-27
  • 2021-12-06
  • 2021-12-10
  • 2021-08-22
猜你喜欢
  • 2021-12-19
  • 2021-04-09
  • 2021-11-30
  • 2021-11-23
  • 2021-07-21
  • 2021-08-20
  • 2022-12-23
相关资源
相似解决方案