一、Java内存模型组成部分 及 与JVM内存结构和物理机的区别
1)主内存
首先,Java虚拟机的主内存与物理机的主内存并不是一个东西,因为"java内存模型"屏蔽了各种硬件和操作系统的内存访问差异,实现了让java在各种平台上都能达到一致的访问效果,jdk1.2建立起来,到jdk5得以完善。
所以java虚拟机的主内存物理上仅是虚拟机内存的一部分。主内存(main memory)存储了所有的变量
2)工作内存
每条线程还有自己的工作内存(working memory,可与处理器的高速缓存类比),工作内存保存了被该线程使用的主内存副本(并不会把整个对象复制一份,而是对象的引用,对象中某个线程需要访问的字段可能被复制)。线程对变量的所有操作(读取,赋值等)都必须在工作内存中进行,而不能直接读写主内存中数据。线程间变量值的传递必须通过主内存来完成,无法直接访问对方工作内存中的变量。(volatile变量自然有工作内存的拷贝,但由于它的特殊操作顺序性规定,看起来像是直接在主内存中读写访问,所以它也遵循上面的规则)
3)与JVM内存结构以及物理机内存的关联
这边的主内存,工作内存和Java内存区域的堆,栈,方法区并不是一个层次的内存划分,没有任何关系,不能画等号。主内存只对应堆里面对象实例数据部分,工作内存则对应虚拟机栈中的一部分区域。对应物理机,主内存直接对应物理硬件的内存,而为了获取更好的速度,虚拟机可能会让工作内存优先存储与寄存器和高速缓存中。