> [CS-Notes](https://cyc2018.github.io/CS-Notes)
认识Java内存模型,就会发现很多在并发下引起的问题都和Java内存模型息息相关。
## 为什么Java有单独的内存模型?
Java 内存模型试图屏蔽各种硬件和操作系统的内存访问差异,以实现让 Java 程序在各种平台下都能达到一致的内存访问效果。
## 模型概述
处理器上的寄存器的读写的速度比内存快几个数量级,为了解决这种速度矛盾,在它们之间加入了高速缓存。
加入高速缓存带来了一个新的问题:缓存一致性。如果多个缓存共享同一块主内存区域,那么多个缓存的数据可能会不一致,需要一些协议来解决这个问题。
![image](https://cs-notes-1256109796.cos.ap-guangzhou.myqcloud.com/942ca0d2-9d5c-45a4-89cb-5fd89b61913f.png)
所有的变量都存储在主内存中,每个线程还有自己的工作内存,工作内存存储在高速缓存或者寄存器中,保存了该线程使用的变量的主内存副本拷贝。
**线程只能直接操作工作内存中的变量,不同线程之间的变量值传递需要通过主内存来完成。**
## 内存间交互操作
Java 内存模型定义了 8 个操作来完成主内存和工作内存的交互操作。
![image](https://cs-notes-1256109796.cos.ap-guangzhou.myqcloud.com/8b7ebbad-9604-4375-84e3-f412099d170c.png)
+ read:把一个变量的值从主内存传输到工作内存中
+ load:在 read 之后执行,把 read 得到的值放入工作内存的变量副本中
+ use:把工作内存中一个变量的值传递给执行引擎
+ assign:把一个从执行引擎接收到的值赋给工作内存的变量
+ store:把工作内存的一个变量的值传送到主内存中
+ write:在 store 之后执行,把 store 得到的值放入主内存的变量中
【学习】Java内存模型