Java内存模型(Java Memory Model,JMM)
它规范了Java虚拟机和计算机内存是如何协同工作的,它规定了一个线程如何和何时可以看到其它线程修改过的共享变量的值,以及在必须时如何同步的访问共享变量。
Java内存模型如图:
堆(Heap): 运行时的数据区,由垃圾回收来负责的。优势是可以动态的分配内存大小,生存期也不用提前告诉编译器,因为它是在运行时动态分配内存的,垃圾回收机制回自动的收走不再使用的数据,但是存取速度较慢。
栈(Stack): 存取速度比堆要快,仅次于计算机中的寄存器,栈的数据是可以共享的,缺点是存在栈中的数据大小与生存期确定的,缺乏一些灵活性,一般存储一些基本的类型的变量(int double char等)
调用栈和本地变量要存在线程栈中,对象存放在堆上。假设同一时刻两个线程都拥有一个对象的引用,同时调用对象的成员方法,则两个线程栈都会拥有该方法的私有拷贝。
计算机硬件架构如图:
CPU Registers : CPU寄存器 是CPU内存的基础。CPU在寄存器上执行的速度远大于在主存上执行的速度。大于缓存的速度。
CPU Cache : 高速缓存 CPU和主存的缓冲区,解决CPU和主存速度不匹配的问题。
RAM - Main Memory : 主存一个计算机有一个主存,所有CPU都可访问主存,一般先将主存的数据读取到缓存中进行操作。
Java内存模型和硬件结构的一些关联: