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

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并发编程的艺术》

    原文作者:java内存模型
    原文地址: https://blog.csdn.net/byhook/article/details/83038796
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞