Java 内存模型
2016-11-28 14:16
169 查看
线程之间的共享变量存储在主内存(main memory)中,每个线程都有一个私有的本地内存(local memory),本地内存中存储了该线程以读/写共享变量的副本。_
本地内存是JMM(Java内存模型)的一个抽象概念,并不真实存在。它涵盖了缓存,写 缓冲区,寄存器以及其 他的硬件和编译器优化。Java内存模型的抽象示意图如下图:
![](https://cloud.githubusercontent.com/assets/9150767/13448138/81f142d6-e05b-11e5-8534-c2f383b5497d.png)
对于一个简单的 i++ 操作,结合上图1 ,会发生如下的步骤:
read:作用于主内存中,把主内存中一个变量的值传输到 工作内存 中。
load:作用于工作内存,把从read 操作从主内存中得到的值放入到工作内存的副本中。
use:把工作内存中的该副本值传递给执行引擎(也就是操作数栈中)。
assign:作用于工作内存,把执行引擎执行后的新值传递给该工作内存的变量。
store:作用于工作内存,把工作内存中该变量的值传送到 主内存中去。
write:作用于主内存的变量,把store 操作 得到的值写入到 主内存的该变量中。
所以说,一个 i++操作并不是原子性的。这上述的这些步骤中,可能会有其他线程对主内存的变量进行操作,从而导致出现多线程问题。
本地内存是JMM(Java内存模型)的一个抽象概念,并不真实存在。它涵盖了缓存,写 缓冲区,寄存器以及其 他的硬件和编译器优化。Java内存模型的抽象示意图如下图:
![](https://cloud.githubusercontent.com/assets/9150767/13448138/81f142d6-e05b-11e5-8534-c2f383b5497d.png)
对于一个简单的 i++ 操作,结合上图1 ,会发生如下的步骤:
read:作用于主内存中,把主内存中一个变量的值传输到 工作内存 中。
load:作用于工作内存,把从read 操作从主内存中得到的值放入到工作内存的副本中。
use:把工作内存中的该副本值传递给执行引擎(也就是操作数栈中)。
assign:作用于工作内存,把执行引擎执行后的新值传递给该工作内存的变量。
store:作用于工作内存,把工作内存中该变量的值传送到 主内存中去。
write:作用于主内存的变量,把store 操作 得到的值写入到 主内存的该变量中。
所以说,一个 i++操作并不是原子性的。这上述的这些步骤中,可能会有其他线程对主内存的变量进行操作,从而导致出现多线程问题。
相关文章推荐
- 修复 Java 内存模型,第 1 部分(什么是 Java 内存模型,最初它是怎样被破坏的?)
- Java 线程/内存模型的缺陷和增强
- java 内存模型
- Java内存结构与模型
- 深入理解JVM—JVM内存模型(很经典) (部分摘自 深入JAVA虚拟机 周志明著)
- Synchronize 与 JAVA 内存模型
- 一,谈谈JAVA线程的运行内存模型【JAVA内存模型】
- 修复 Java 内存模型,第 2 部分
- 修复 Java 内存模型<1>
- Java 内存模型
- Java 线程/内存模型的缺陷和增强-Java基础-Java-编程开发
- java 内存模型
- JMM Java的内存模型
- 修复 Java 内存模型,第 2 部分
- Java 内存模型及GC原理
- 修复 Java 内存模型,第 2 部分(在 JSR 133 中 JMM 会有什么改变?)
- Java 线程/内存模型的缺陷和增强
- Sun Java HotSpot™ Virtual Machine内存模型与垃圾回收
- java 内存模型
- 关于Java的内存模型,使用的是尚学堂的图