ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JVM运行时数据区域概述

2021-08-17 13:31:43  阅读:155  来源: 互联网

标签:Java 虚拟机 计数器 区域 概述 内存 JVM 线程 方法


JVM运行时数据区域

  1. 程序计数器

可以看作是当前线程所执行的字节码的行号指示器,通过计数器的值来选取下一条需要执行的字节码指令,程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都需要这个计数器来完成。

每条线程都需要有独立的程序计数器,各个线程之间计数器互不影响,独立存储。

如果线程正在执行的是一个Java方法,这个计数器记录的是正在执行的虚拟机字节码指令的地址;如果正在执行的是本地(Native)方法,这个计数器值则应为空(Undefined)。此内存区域是唯一一个在《Java虚拟机规范》中没有规定任何OutOfMemoryError 情况的区域。

  1. Java虚拟机栈

也是线程私有的,生命周期与线程相同。

虚拟机栈描述得失Java方法执行的线程内存模型:每个方法被执行的时候,Java虚拟机都会同步创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法被调用直至执行完毕的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。

  1. 本地方法栈

本地方法栈则是为虚拟机栈使用到的本地(Native)方法服务。

  1. Java堆

Java堆是被所有线程共享的一块内存区域,是虚拟机所管理的内存中最大的一块。

由于即时编译技术的进步,尤其是逃逸分析技术的日渐强大,栈上分配、标量替换 优化手段导致一些微妙的变化悄然发生,让Java对象实例都分配在堆上也渐渐变得不是那么绝对了。

  1. 方法区

方法区是各个线程共享的内存区域,它用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器后的代码缓存等数据。

注意 这个方法区不等于“永久代”,只是当时HotSpot虚拟机设计团队选择把收集器的分代设计扩展至方法区,或者说是用永久代来实现方法区而已,这样使得HotSpot的垃圾收集器能够像管理Java堆一样管理这部分内存,省去专门为方法区编写内存管理代码的工作。JDK8之后放弃了永久代,改用元空间来代替。

  1. 1. 运行时常量池

运行时常量池(Runtime Constant Pool)是方法区的一部分,Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池表(constant Pool Table),

  1. 直接内存

Direct Memory 直接内存不是虚拟机运行时数据区的一部分,

在JDK1.4中新加入了NIO(New Input/Output)类,引入了一种基于通道(Channel)与缓冲区(Buffer)的 I/O 方式,他可以使用Native 函数库直接分配堆外内存,然后通过一个存储在Java堆里面的 DirectByteBuffer 对象作为这块内存的引用进行操作。这样能在一个场景中提高性能,因为避免在Java堆和Native堆中来回复制数据。

 

来源《深入理解JVM虚拟机》

标签:Java,虚拟机,计数器,区域,概述,内存,JVM,线程,方法
来源: https://www.cnblogs.com/wnqc/p/15151871.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有