一、内存模型
Java虚拟机规范中试图定义一种Java内存模型(Java Memory Model)来屏蔽掉各种硬件和操作系统之间的内存访问差异,以实现Java程序在各种平台下都能达到一致的内存访问效果。
Java内存模型的主要目标是定义程序中各个变量的访问规则,即在虚拟机中将变量存储到内存和从内存取出变量这样的底层细节。此处所说的变量包括实例变量,类变量和数组,不包含局部变量和方法参数,因为后者是线程私有的,不会被共享,自然就不会存在竞争 问题。
Java内存模型规定了所有的变量都存储在主内存(Main Memory)中(此处的主内存是指虚拟机内存中的一部分)。每条线程还有自己的工作内存(Working Memory),线程的工作内存中保存了该线程使用到的变量的主内存副本的拷贝(如果是引用类型,那么拷贝的是对象的引用,或者对象的某个字段属性),线程对变量的所有操作都必须在工作内存中进行,而不能直接读写主内存中的变量。同样,工作线程之间也无法进行彼此访问,线程间变量值的传递均需要通过主内存来完成,三者交互关系图如下。
这里所讲的主内存、工作内存和Java内存区域中的堆、栈、方法区、虚拟机栈,程序计数器等并不是同一个层次的内存划分。但是如果一定要找到一个对应关系,那么从变量、主内存和工作内存的定义来看,主内存主要对应于Java堆中的对象实例数据部分,而工作内存对应虚拟机栈中的局部变量表。从硬件层面来说,主内存对应于内存条,而工作内存对应于CPU的缓存和寄存器。
二、内存间交互操作
锁定(锁定)、解锁(unlock)、读取(read)、载入(loading)、使用(use)、赋值(assign)、存储(store)、写入(write)
注意:Java中的非原子操作,会导致volatile变量在运算在并发是不安全的。
- 大小: 53.5 KB
分享到:
相关推荐
Java内存模型是Java虚拟机规范中定义的一部分,它规定了Java程序中变量的读写行为,以及线程之间的交互规则。理解Java内存模型对于编写正确、高效的多线程程序至关重要。在Java 5之前,Java内存模型的描述比较模糊,...
Java内存模型,简称JMM(Java Memory Model),是Java编程语言规范的一部分,它定义了程序中各个线程如何访问和修改共享变量,以及如何确保数据的一致性。深入理解Java内存模型对于编写高效的并发程序至关重要。本文...
Java内存模型是并发编程中一个至关重要的概念,它定义了共享变量的访问规则,以及这些变量如何在多线程环境下进行读写操作。在深入理解Java内存模型之前,我们需要先了解并发编程模型的分类,然后掌握Java内存模型的...
Java程序员了解CPU以及相关的内存模型,对于深入理解Java内存模型以及并发编程至关重要。CPU作为计算机硬件的核心,其架构和工作原理影响着软件的性能和执行效率。尤其在Java这种多线程、高并发的编程语言中,对CPU...
### Java内存模型的历史变迁 #### 一、引言 随着多核处理器的普及与高性能计算需求的增长,Java作为主流编程语言之一,对于并发处理的支持变得越来越重要。Java内存模型(Java Memory Model,简称JMM)作为Java...
Java内存模型,简称JMM(Java Memory Model),是Java编程语言规范的一部分,它定义了线程如何共享和访问内存,以及在多线程环境中如何保证数据一致性。理解JMM对于编写高效、正确且线程安全的Java代码至关重要。 ...