JMM约定将内存划分为工作区和公共内存数据区域。工作区为线程私有,基本类型数据和对象引用的地址存储在工作区。当需要对内存区域的数据进行读写时复制到工作区,修改完成后刷新到内存区供其他线程使用。这其中可能会产生数据不一致性的问题,使用Volatile和synchronized以及锁等机制来保证。编码规则,需要注意原子性、可见性、有序性。
JVM是对于JMM约定的具体实现方法,将内存分为五个部分,方法区,堆,JVM栈,本地方法栈,程序计数器。前两者属于线程共有,后三者属于线程私有。方法区存储类、常量、JIT即时编译的方法代码,类加载信息的引用等等。堆存储对象。JVM栈主要由方法栈帧组成,栈帧包含方法内的局部变量,操作数栈、动态链接和出口地址。本地方法是JVM本身运行的方法和调用其他语言的区域。程序计数器记录线程执行的地址,方便线程切换。