JVM运行时数据区域

程序计数器

1、 线程所执行的字节码的行号指示器;

2、JVM的多线程是通过线程轮流切换并分配处理器执行时间的方式;

3、 每条线程都需要有一个独立的程序计数器,所以是线程私有的内存区域;

4、 执行Java方法,记录的是正在执行的虚拟机字节码指令的地址;

5、 执行Native方法,计数器值为空;

6、 唯一一个在JVM规范中没有规定任何OOM情况的区域;

Java虚拟机栈

1、 是线程私有的,其生命周期与线程相同;

2、 是Java方法执行的内存模型;

3、 每个方法执行的同时会创建一个栈帧,每个方法从调用到执行完成的过程,对应着一个栈帧在虚拟机栈中从入栈到出栈;

4、 栈帧存放内容:局部变量表、操作数栈、动态链接、方法出口;

5、 局部变量表存放内容:编译期可知的基本数据类型(byte,short,int,long,float,double,boolean,char)、对象引用、returnAddress类型;

6、 64位长度的long和double类型的数据会占用2个局部变量空间,其余的占用1个;

7、 局部变量表所需内存空间大小,在编译期完成分配,方法运行期间不会改变;

8、 Java虚拟机栈会存在以下两种类型的异常:

|异常类型|原因|

|------------|------|

|StackOverflowError|线程所申请的栈深度大于虚拟机所允许的最大深度|

|OutOfMemoryError|JVM栈可以动态扩展,如果扩展时无法申请到足够的内存|

本地方法栈

1、 作用与Java虚拟机栈相似,为JVM使用的Native方法服务;

2、 有的虚拟机(例如Sun的HotSpot)把本地方法栈和虚拟机栈合二为一;

3、 也会抛出两种类型的异常:StackOverflowError和OutOfMemoryError;

Java堆区

1、 JVM管理的内存中最大的一块;

2、 是被所有线程共享的一块内存区域;

3、 虚拟机启动时创建;

4、 唯一目的:存放对象实例(所有的对象实例和数组都是在堆上分配);

5、 是垃圾收集器管理的主要区域,也被称为“GC堆”;

6、 采用分代收集算法,Java堆细分为:新生代、老年代。再细致一点的有:Eden空间、From Survivor空间、To Survivor空间;

7、 Java堆可以处于物理上不连续的内存空间中,只要逻辑连续即可;

8、 通过JVM参数 -Xmx和-Xms控制扩展;

9、 异常类型

|异常类型|原因|

|------------|------|

|OutOfMemoryError|堆中没有内存完成实例分配,且堆也无法再扩展|

方法区

1、 与堆一样,也是各个线程共享的内存区域;

2、 存储已经被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码;

3、 HotSpot中称为永久代;

4、 JDK1.7中已经把原本在永久代中的字符串常量池移出;

5、 该区域内存回收的目标主要是:针对常量池的回收和对类型的卸载;

6、异常类型

|异常类型|原因|

|------------|------|

|OutOfMemoryError|方法区无法满足内存分配需求时|

原文地址:https://www.cnblogs.com/muscleape/p/10229226.html

时间: 2024-11-06 13:53:21

JVM运行时数据区域的相关文章

JVM【第二回】:【JVM运行时数据区域详解】

上一回对JVM运行时数据区域的组织结构进行了概述,这一回将对各个组成进行详解. 程序计数器[Program Counter Register] 程序计数器是一块较小的内存空间,它的作用可以看做是当前线程所执行的字节码的行号指示器.在虚拟机的概念模型里,字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支.循环.跳转.异常处理.线程恢复等基础功能都需要依赖这个计数器完成. 由于Java虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的,在任何一个确定的

JVM运行时数据区域分析

Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同数据区域.这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有些区域则是依赖用户线程的启动和结束而建立和销毁. 原文链接:http://sparkyuan.me/2016/04/22/JVM运行时数据区域/ ,转载请注明出去 程序计数器(PC) 程序计数器(Program Counter Register)是一块较小的内存空间,它的作用可以看做是当前线程所执行的字节码行号指示器. - 当前线

JVM 运行时数据区域

Java虚拟机管理的内存包括以下几个运行时数据区域: 1.程序计数器: 程序计数器是一块比较小的内存空间,是当前线程执行的字节码行号指示器.Java多线程是通过线程轮流切换来实现的,所以每个线程都有一个自己独立的程序计数器,各个线程的程序计数器互补干扰. 2.Java虚拟机栈 Java虚拟机栈描述的是Java方法的执行模型:每个方法执行的时候都会创建一个帧栈用于存放局部变量表,操作栈,动态链接,方法出口等信息.一个方法的执行过程,就是这个方法对于帧栈的入栈出栈过程. 3.本地方法栈 本地方法栈与

JVM【第一回】:【JVM运行时数据区域总览】

Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机的进程的启动而存在,有些区域则是依赖用户的线程的启动和结束而建立和销毁.Java虚拟机所管理的内存将会包括一下几个运行时数据区域,如下图所示: 欲知后事如何,且听下回分解

深入理解JVM:JVM运行时数据区域分类

JVM在执行java程序的过程中会把他所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途和创建.销毁时间.有些区域随着虚拟机的启动而存在,有些区域则依赖用户线程的启动和结束而建立和销毁.根据<Java虚拟机规范1.7>规定,Java虚拟机所管理的内存分为以下几个区域: 程序计数器.Java虚拟机栈.本地方法栈.Java堆.方法区.运行时常量池.直接内存 程序计数器 是一块较小的内存空间,他可以看作是当前线程所执行的字节码的行号指示器.在虚拟机的概念模型里,字节码解释器工作时就是通过

JVM调优系列:(二)JVM运行时数据区域

1) Method Area 2) Heap 3) Java Stacks 4) PC Registers 5) Native Method Stacks JAVA的JVM的内存模型大致可分为3个区: 堆区: 1.存储的全部是对象,每个对象都包含一个与之对应的class的信息.(class的目的是得到操作指令) 2.jvm只有一个堆区(heap)被所有线程共享,堆中不存放基本类型和对象引用,只存放对象本身 栈区: 线程在执行一个Java方法时候,它的PC寄存器总是指向下一条需要执行的指令, 而它

JVM运行时数据区域解析

Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想进去,墙里面的人想出来. Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同数据区域.这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有些区域则是依赖用户线程的启动和结束而建立和销毁. 所有线程共享数据区 线程隔离数据区 一.程序计数器(寄存器) 当前线程所执行的字节码行号指示器 字节码解释器工作依赖计数器控制完成 通过执行线程行号记录,让线程轮流切换各条线程

轻松认识JVM运行时数据区域(使用思维导图)

下面是个人阅读周志明编写的深入浅出Java虚拟机做成思维导图的笔记,线条.颜色和图片的视觉印象比起单纯文字笔记好得太多了,文字笔记的枯燥以及硬性记忆我就不再多说,特别对于JVM这块略微有点枯燥的知识,更加需要采取更好的方式来认识它.思维导图的模式更加符合大脑认识事物的流程.我将重点的知识抽取出来,又尽量把详细知识描述上去.

思维导图之JVM运行时数据区域

下面是个人阅读周志明编写的深入浅出Java虚拟机做成思维导图的笔记,线条.颜色和图片的视觉印象比起单纯文字笔记好得太多了,文字笔记的枯燥以及硬性记忆我就不再多说,特别对于JVM这块略微有点枯燥的知识,更加需要采取更好的方式来认识它.思维导图的模式更加符合大脑认识事物的流程.我将重点的知识抽取出来,又尽量把详细知识描述上去.