Java内存模型——基础
JMM因何产生 由于计算机的存储设备与处理器的运算能力之间有几个数量级的差距,所以现代计算机系统都不得不加入一层读写速度尽可能接近处理器运算速度的高速缓存(Cache)来作为内存与处理器之间的缓冲——将运算需要使用到的数据复制到缓存中,让运算能快速进行,当运算结束后再从缓存同步回内存之中没这样处理器就无需等待缓慢的内存读写了。 基于高速缓存的存储交互很好地解决了处理器与内存的速度矛盾,但是引入了一个新的问题——缓存一致性(Cache Coherence)。在多处理器系统中,每个处理器都有自己的高速缓存,而他们又共享同一主存,当多个处理器的运算任务都涉及同一块主内存区域时, 将可能导致各自的缓存数据不一致的情况, 而这也是并发编程必须考虑的问题,为了解决一致性的问题,Java虚拟机规范定义了Java内存模型(Java Memory Model ,JMM)来屏蔽了各种硬件和操作系统的内存访问差异,以实现让 Java程序在各种平台下都能达到一致的内存访问效果。Java内存模型的关键技术点围绕多线程的原子性、可见性和有序性建立。 主内存与工作内存 Java内存模型的主要目标是定义程序中各个变量...
