Java线程工作内存与主内存变量交换过程及volatile关键字理解
2017-09-27 10:06
375 查看
1. Java内存模型规定在多线程情况下,线程操作主内存变量,需要通过线程独有的工作内存拷贝主内存变量副本来进行。此处的所谓内存模型要区别于通常所说的虚拟机堆模型:
2. 线程独有的工作内存和进程内存(主内存)之间通过8中原子操作来实现,如下图所示:
原子操作的规则(部分):
1) read,load必须连续执行,但是不保证原子性。
2) store,write必须连续执行,但是不保证原子性。
3) 不能丢失变量最后一次assign操作的副本,即遍历最后一次assign的副本必须要回写到MainMemory中。
其它规则详见《深入理解Java虚拟机》第12章 Java内存模型与线程
3. volatile关键字
定义为volatile类型的变量拥有两种语义:
1) 变量的修改对所有线程可见
理解:
线程中每次use变量时,都需要连续执行read->load->use几项操作,即所谓的每次使用都要从主内存更新变量值,这样其它线程的修改对该线程就是可见的。
线程每次assign变量时,都需要连续执行assign->store->write几项操作,即所谓每次更新完后都会回写到主内存,这样使得其它线程读到的都是最新数据。
2)禁止指令重排
文章转载自:http://www.cnblogs.com/wrencai/p/5704331.html,感谢分享!
2. 线程独有的工作内存和进程内存(主内存)之间通过8中原子操作来实现,如下图所示:
原子操作的规则(部分):
1) read,load必须连续执行,但是不保证原子性。
2) store,write必须连续执行,但是不保证原子性。
3) 不能丢失变量最后一次assign操作的副本,即遍历最后一次assign的副本必须要回写到MainMemory中。
其它规则详见《深入理解Java虚拟机》第12章 Java内存模型与线程
3. volatile关键字
定义为volatile类型的变量拥有两种语义:
1) 变量的修改对所有线程可见
理解:
线程中每次use变量时,都需要连续执行read->load->use几项操作,即所谓的每次使用都要从主内存更新变量值,这样其它线程的修改对该线程就是可见的。
线程每次assign变量时,都需要连续执行assign->store->write几项操作,即所谓每次更新完后都会回写到主内存,这样使得其它线程读到的都是最新数据。
2)禁止指令重排
文章转载自:http://www.cnblogs.com/wrencai/p/5704331.html,感谢分享!
相关文章推荐
- Java线程工作内存与主内存变量交换过程及volatile关键字理解
- Java 多线程 (PART XIV) volatile关键字和变量在内存中的工作过程
- Java线程同步机制synchronized关键字的理解
- java多线程学习一线程安全之内存、synchronized、volatile
- Java线程入门学习5----volatile和synchronized关键字
- JAVA学习.JAVA对象构建内存理解&静态方法和变量的理解和使用.
- Java线程:volatile关键字
- Java线程:volatile关键字
- 谈谈java线程锁synchronized关键字和volatile关键字
- Java线程:volatile关键字
- Java:volatile 关键字的一点理解
- 深入理解Java虚拟机笔记---volatile变量的特殊规则
- Java内存的原型及工作原理理解
- Java线程:volatile关键字
- java中volatile关键字的理解
- Java线程:volatile关键字
- Java线程同步机制synchronized关键字的理解
- Java线程:volatile关键字
- java线程内存模型,线程、工作内存、主内存
- Java线程同步机制synchronized关键字的理解