Java线程之间的通信由Java内存模型(简称为JMM)控制,JMM决定一个线程对共享变量的写入何时对另一个线程可见。从抽象的角度来 看,JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存(mainmemory)中,每个线程都有一个私有的本地内存(local memory),本地内存中存储了该线程以读/写共享变量的副本。本地内存是JMM的一个抽象概念,并不真实存在。它涵盖了缓存,写缓冲区,寄存器以及其
他的硬件和编译器优化。Java内存模型的抽象示意图如下:
下面请看详细的代码分析过程:
int i = 0; //实例变量,保存在堆内存里面
getNextId(){
return i++;
}
以上代码在JVM中的执行过程:
JVM首先在JVM堆给i分配一个内存存储场所,并存储其值为0。线程启动后,会自动分配一个操作数栈。当程序执行到returni++,JVM并不是简单的一个步骤就可以完成。i++动作在jvm中分为装载i,读取i,进行i+1操作,存储i及写入i等5个步骤。
装载i:线程将i值从JVM堆复制到本地内存
读取i:从本地内存中读取i到操作数栈
进行i+1操作:由线程来操作,在方法栈中执行
存储i:将i+1的值赋值给i,然后存储到本地内存
写入i:将本地内存中i的值写入到java堆内存
因为main memory中的i和working memory中的i同步是需要时间的,如果在多线程环境下,假设线程A已经执行了i+1操作,当尚未完成写入i操作,线程b就完成了装载i的过程,那么当线程b执行完成,得到的值和a就是一样的。
当多线程执行此段代码的时候,线程a执行到getNextId()方法,JVM知道该方法有关键字,于是在执行其他动作前,首先在对象的实例前面加上一个lock,然后再继续执行return i++,而此时如果线程b并发访问getNextId()方法,JVM观察这个对象的实例上面有lock,于是将线程b放入等待执行的队列,只有等线程a的returni++执行完毕,jvm才会释放对象实例上面的锁,重新标记为unlock,这时当线程调度到线程b,线程b才得以执行getNextId()方法。
JAVA的线程无处不在
在装载i,读取i的过程中,因为涉及到与内存打交道,CPU就处于空闲状态,为了更有效的利用CPU,JAVA就使用多线程的方式执行程序。由此可以看出:Java内存模型决定了使用线程,则会极大提高程序的运行效率,所以线程无处不在!
感谢金丝燕大学校长
分享到:
相关推荐
title: 第12章 Java内存模型与线程 12.1 概述- 7 深入理解Java虛拟机:JVM高级特性与最佳实践(第3版)- 5第五部分 高效并发- 第1
Java内存模型和线程安全,多线程开发,高并发处理,内存模型分析
可以先看我的博客在下载,...增加高速缓存;为了使得处理器内部的运算单元能尽量被充分利用,处理器可能会对代码进行乱序执行优化,处理器会在计算机之后将乱序执行的结果重组,保证该结果与顺序执行结果是一致的
java线程-Java内存模型;java线程-Java内存模型;java线程-Java内存模型;java线程-Java内存模型;java线程-Java内存模型;java线程-Java内存模型java线程-Java内存模型
java内存模型和线程安全,详细解析java的 堆栈模型和线程机制
JSR-133 :Java TM 内存模型与线程规范
JavaTM内存模型与线程规范,描述了Java中多线程执行执行时的相关语义及规则
Java线程之间的通信由Java内存模型(本文简称为JMM)控制,JMM决定一个线程对共享变量的写入何时对另一个线程可见。从抽象的角度来看,JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存(main ...
java内存模型,对初学者比较实用,理解后有助于多线程编程等
java线程之间的通信对程序员完全透明,内存可见性问题很容易困扰java程序员,本文试图揭开java内存模型神秘的面纱。本文大致分三部分:重排序与顺序一致性;三个同步原语(lock,volatile,final)的内存语义,重...
Java 内存模型的抽象 4 重排序 6 处理器重排序与内存屏障指令 7 happens-before 10 重排序 13 数据依赖性 13 as-if-serial 语义 13 程序顺序规则 15 重排序对多线程的影响 15 顺序一致性 19 数据竞争与顺序...
Java内存模型的抽象 重排序 处理器重排序与内存屏障指令 happens-before 重排序 数据依赖性 as-if-serial 语义 程序顺序规则 重排序对多线程的影响 顺序一致性 数据竞争与顺序一致性保证 顺序一致性内存模型 同步...
详细介绍Java内存,ava线程之间的通信对程序员完全透明,内存可见性问题很容易困扰java程序员,本文试图揭开java内存模型神秘的面纱。本文大致分三部分:重排序与顺序一致性;三个同步原语(lock,volatile,final)...
NULL 博文链接:https://zdsyouxiang.iteye.com/blog/939284
在并发编程中,我们需要处理两个关键问题:线程之间如何通信及线程之间如何同步(这里的线程是指并发执行的活动实体)。通信是指线程之间以何种机制...在命令式编程中,线程之间的通信机制有两种:共享内存和消息传递。
高效并发-java内存模型与线程 线程安全与锁优化 1 标记-清除算法:首先标记所有需要回收的对象(引用计数或可达性分析算法标记),在标记完成后统一回收所有被标记的对象。 缺点:效率问题,标记和清除两个过程效率都...
Java内存模型,即:JMM。当程序执⾏并⾏操作时,如果对数据的访问和操作不加以控制,那么必 然会对程序的正确性造成破坏。因此,我们需要在深⼊了解并⾏机制的前提下,再定义⼀种规则, 来保证多个线程间可以有效地...
首先希望大家喜欢我制作的文档,如果文档中有什么误解的地方,望告诉一下,5分是也不多,是系统默认的,那么就5分咯,java多线程详解,线程池原理,8种锁,java内存模型......
Java线程之间的通信由Java内存模型简称JMM(Java Memory Mode)控制,JMM决定一个线程对共享变量的写入何时对另一个线程可见。从抽象的角度来看,JMM是这样定义线程和主内存之间的抽象关系的:线程之间的共享变量...