最新java内存模型_java内存模型

最新java内存模型_java内存模型1.Java内存模型Java内存模型是每个java程序员必须掌握理解的,这是Java的核心基础,对我们编写代码特别是并发编程时有很大帮助。由于Java程序是交由JVM执行的,所以我们在谈Java内存区域划分的时候事实上是指JVM内存区域划分。1.1.Java程序执行流程回顾如图所示首先Java源代码文件(.java后缀)会被Java编译器编译为字节码文件(.class后缀),然后由JVM中…

大家好,又见面了,我是你们的朋友全栈君。

1.   Java内存模型

Java内存模型是每个java程序员必须掌握理解的,这是Java的核心基础,对我们编写代码特别是并发编程时有很大帮助。由于Java程序是交由JVM执行的,所以我们在谈Java内存区域划分的时候事实上是指JVM内存区域划分。

1.1. Java程序执行流程回顾

cb4e3fc3f817449393dd0724b8d1abb3.png

如图所示

首先Java源代码文件(.java后缀)会被Java编译器编译为字节码文件(.class后缀),

然后由JVM中的类加载器加载各个类的字节码文件,

加载完毕之后,交由JVM执行引擎执行。

Java内存模型指的就是Runtime Data Area(运行时数据区),即程序执行期间用到的数据和相关信息保存区。

1.2. Java内存模型

根据 JVM 规范,JVM 内存共分为虚拟机栈、堆、方法区、程序计数器、本地方法栈五个部分。结构如下图:

bcd64677c931dd68e42e3394fd0a24d9.png

1.2.1.   PC程序计数器:

l  每个线程对应有一个程序计数器。

l  各线程的程序计数器是线程私有的,互不影响,是线程安全的。

l  程序计数器记录线程正在执行的内存地址,以便被中断线程恢复执行时再次按照中断时的指令地址继续执行

1.2.2.   Java栈JavaStack(虚拟机栈JVM Stack):

l  每个线程会对应一个Java栈;

l  每个Java栈由若干栈帧组成;

l  每个方法对应一个栈帧;

l  栈帧在方法运行时,创建并入栈;方法执行完,该栈帧弹出栈帧中的元素作为该方法返回值,该栈帧被清除;

l  栈顶的栈帧叫活动栈,表示当前执行的方法,才可以被CPU执行;

l  线程请求的栈深度大于虚拟机所允许的深度,将抛出StackOverflowError异常;

l  栈扩展时无法申请到足够的内存,就会抛出OutOfMemoryError异常;

a7aedabb21a3c125dc0fe1a490f49deb.png

1.2.3.   方法区MethodArea

l  方法区是Java堆的永久区(PermanetGeneration)

l  方法区存放了要加载的类的信息(名称、修饰符等)、类中的静态常量、类中定义为final类型的常量、类中的Field信息、类中的方法信息,

l  方法区是被Java线程共享的

l  方法区要使用的内存超过其允许的大小时,会抛出OutOfMemoryError: PremGen space的错误信息。

1.2.4.   常量池ConstantPool:

l  常量池是方法区的一部分。

l  常量池中存储两类数据:字面量和引用量。

字面量:字符串、final变量等。

引用量:类/接口、方法和字段的名称和描述符,

l  常量池在编译期间就被确定,并保存在已编译的.class文件中

1.2.5.   本地方法栈Native Method Stack:

l  本地方法栈和Java栈所发挥的作用非常相似,区别不过是Java栈为JVM执行Java方法服务,而本地方法栈为JVM执行Native方法服务。

l  本地方法栈也会抛出StackOverflowError和OutOfMemoryError异常。

1.3. Java内存模型工作示意图

3d600a0cb4e3843783aa06651fea3277.png

1)         首先类加载器将Java代码加载到方法区

2)         然后执行引擎从方法区找到main方法

3)         为方法创建栈帧放入方法栈,同时创建该栈帧的程序计数器

4)         执行引擎请求CPU执行该方法

5)         CPU将方法栈数据加载到工作内存(寄存器和高速缓存),执行该方法

6)         CPU执行完之后将执行结果从工作内存同步到主内存

线程计算的时候,原始的数据来自内存,在计算过程中,有些数据可能被频繁读取,这些数据被存储在寄存器和高速缓存中,当线程计算完后,这些缓存的数据在适当的时候应该写回内存。

当个多个线程同时读写某个内存数据时,就会产生多线程并发问题,要解决这些问题就涉及到多线程编程三个特性:原子性,有序性,可见性。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/156619.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月7日 下午5:46
下一篇 2022年7月7日 下午5:46


相关推荐

  • 全网最全Claude Code免费实践教程,附带免费大模型Token申请教程

    全网最全Claude Code免费实践教程,附带免费大模型Token申请教程

    2026年3月15日
    2
  • 《大话数据结构》边读边感

    《大话数据结构》边读边感第一章:数据结构绪论数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。数据:是描述客观事物的符号,式计算机可以操作的对象,是能被计算机识别,并输入给计算机处理的符号集合。数据输入有两个前提:1、可以输入的计算机中;2、能被计算机程序处理数据元素:是组成数据的,有一定意义的基本单位,在计算机中通常作为整体处理。也被称为记录。数据项:一个数据元素可以由若干个数据项组成;数据项数据不可

    2022年6月24日
    26
  • 人工智能体-Agents 组件详解

    人工智能体-Agents 组件详解

    2026年3月16日
    2
  • 监督学习型神经网络

    监督学习型神经网络兄弟姐妹们,如需转载请标明出处:http://blog.csdn.net/jiangjunshow总目录什么是监督学习?简单的回答是:判断是否是监督学习,就看输入数据是否有标签。输入数据有标签,则为有监督学习,没标签则为无监督学习。对于上面的简单回答,如果你看不懂,是正常的!下面我给出详细回答,如果你还是不明白,那么…….也是正常的。因为有些概念要被接受是需要时间的!坚持不懈地看我

    2022年5月28日
    41
  • Activity启动模式SingleTask和Intent.FLAG_ACTIVITY_CLEAR_TOP区别

    Activity启动模式SingleTask和Intent.FLAG_ACTIVITY_CLEAR_TOP区别Activity启动模式介绍Android启动模式之前,先介绍两个概念task和taskAffinity task:翻译过来就是“任务”,是一组相互有关联的activity集合,可以理解为Activity是在task里面活动的。task存在于一个称为backstack的数据结构中,也就是说,task是以栈的形式去管理activity的,所以也叫可以称为“…

    2022年7月17日
    18
  • 操作系统:银行家算法(C语言代码)详解

    操作系统:银行家算法(C语言代码)详解银行家算法流程图:银行家算法自然语言描述:设Requesti是进程Pi的请求向量,如果Requesti[j]=K,表示进程Pi需要K个Rj类型的资源。当Pi发出资源请求后,系统按下述步骤进行检查:(1)如果Requesti[j]≤Need[i,j],便转向步骤2;否则认为出错,因为它所需要的资源数已超过它所宣布的最大值。(2)如果Requesti[j]≤Available[j],便转向步骤3;否则,表示尚无足够资源,Pi须等待。(3)系统试探着把资源分配给进程Pi,并修改下面数据..

    2022年6月13日
    30

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号