深入理解java虚拟机二,内存管理机制

java 虚拟机自动内存管理。

java虚拟机在执行java程序的过程中会把它所管理的内存划分为若干个不同区域

1 程序计数器

每个线程都有一个独立的计数器,用来指示需要执行的字节码的位置。

2 虚拟机栈

虚拟机栈是用来描述java方法执行的内存模型,每个方法被执行的时候都会同时创建一个栈帧用于储存局部变量表,操作栈,动态链接,方法出口等信息。

每一个方法被调用直至执行完成的过程,就对应着一个栈帧从虚拟机栈中从入栈到出栈的过程。

虚拟机栈线程私有,声明周期和线程一样。

局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法需要在帧中分配多大的局部变量空间是完全确定的,

在方法运行期间不会改变局部变量表的大小

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

当虚拟机栈自动扩展时无法申请到足够内存时会抛出OutOfMemoryError异常

3 本地方法栈

与虚拟机栈作用类似,不过是作用在本地方法上

4 java堆

用途是存放对象实例,在虚拟机启动的时候创建,被所有线程共享。

根据分代收集算法,分为新生代和老年代。

java堆可以处于物理上不连续的内存空间中。

5 方法区

被所有线程共享。用于存储已被虚拟机加载的类信息,常量,静态常量,即时编译器编译后的代码等数据。

垃圾收集行为在这个区域是比较少出现的,这个区域的内存回收目标主要是针对常量池和对类型的卸载。

6 运行时常量池

方法区的一部分,Class文件中除了有类的版本,字段,方法,接口等描述信息外,还有一项是常量池。

用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载之后存放到方法区的运行时常量池。

7 直接内存

本机的直接内存,不受JAVA堆大小限制。

时间: 2024-10-11 02:37:48

深入理解java虚拟机二,内存管理机制的相关文章

Java虚拟机一 内存管理机制

Java虚拟机的内存管理主要分两点:内存分配以及内存回收.· 一.内存分配图: 注: 所占区域的大小与实际的内存大小比例并无直接关系. 解读: 1.如图,分成两种颜色的内存区域,其中蓝色的是线程隔离的数据区,也就是说每一个线程都有自己的这么一个区域存放自己的数据,而青色区域则是线程共享的,里面的数据为所有线程共有,原则上都有权限访问. 2.程序计数器: 用途:用来给程序导航指路的.这个是一块较小的内存空间,可以看做是当前线程执行的字节码的行号指示器.理解就是虚拟机把java源代码编译成了字节码,

【深入理解Java虚拟机】垃圾回收机制

本文内容来源于<深入理解Java虚拟机>一书,非常推荐大家去看一下这本书. 本系列其他文章: [深入理解Java虚拟机]Java内存区域模型.对象创建过程.常见OOM 1.垃圾回收要解决的问题 垃圾收集(Garbage Collection,GC),要设计一个GC,需要考虑解决下面三件事情: (1)哪些内存需要回收? (2)什么时候回收? (3)如何回收? 哪些内存需要回收? 根据<Java内存区域模型.对象创建过程.常见OOM>中介绍的java内存模型,其中,程序计数器.虚拟机栈

Java虚拟机的内存管理

众所周知,Java程序员写的代码是没有办法控制Java对象的内存释放的,完全有JVM暗箱操作. 虽然程序员把内存的释放的任务都交给了Java虚拟机,但是并不代表Java程序就不存在内存泄漏. 反而,某程度上,当出现内存泄漏,Debug会变得难度更大. 所以,Java程序员,有必要去了解Java虚拟机对于内存的管理以及垃圾回收的机制. Java虚拟机是如何判断一个对象可以回收? 当一个对象没有被任何其他所引用时,这个对象被Java虚拟机视为可回收. 早起的虚拟机,使用引用计数的方法判断对象是否可回

《深入理解Java虚拟机》 -- 内存

JVM对于操作系统来说是一种应用程序,JVM要运行的时候,操作系统会创建对应的进程而且分配一定大小的内存. 一.内存结构 当虚拟机得到系统分配的内存后,它在其内存空间中就是老大,管理对象内存的分配以及对象内存的回收,同时可以根据虚拟机的规范对其内存空间划分不同的区域.主要分为运行数据区.执行引擎.本地接口与本地类库.结构如下图: 大多数程序员更多关注的是变量是怎么存储的或者存在哪个区域.还有对象的内存分配关系,所以在这个层面上来看可以分为堆与栈两个内存区域,而这两个区域都是在运行数据区,所以我们

深入了解Java虚拟机和内存管理

1.java程序的执行过程      java源文件->解析器->class文件->java类加载器->java运行时数据区->执行引擎 2.我们接下来看一下java运行时数据区      包含程序计数器,虚拟机栈,本地方法栈,方法区,堆,其中程序计数器,虚拟机栈,本地方法区属于指令,方法区和堆属于数据.  一.程序计数器        用来指示程序执行哪一条指令,这跟汇编语言的程序计数器的功能在逻辑上是一样的.JVM规范中规定,如果线程执行的是非native方法,则程序计数

深入理解Java虚拟机笔记---内存分配与回收策略

Java技术体系中的自动内存管理最终可以归结为自动化地解决了两个问题:给对象分配内存以及回收分配给对象的内存.对象的内存分配往大的方向上讲,就是在堆上分配,对象主要分配在新生代的Eden区上,如果启动了本地线程分配缓冲(-XX:+UseTLAB,默认已开启),将按线程优先在TLAB上分配.少数情况下也可能会直接分配在老年代中,分配的规则并不是百分之百固定的,其细节取决于当前使用的是哪一种垃圾收集器组合,还有虚拟机中与内存相关的参数设置. 下面是几条主要的最普遍的内存分配规则: 1.对象优先在Ed

JAVA之自动内存管理机制

一.内存分配 1.JVM体系结构 2.运行时数据区域 3.内存分配二.内存回收 1.垃圾收集算法 2.垃圾收集器三.相关参考一.内存分配JVM体系结构 在了解自动内存管理的内存分配之前,我们先看下JVM的体系结构.代码编译的结果是从本地机器码转变为字节码,经过类加载器加载到虚拟机后才能执行程序.JVM的体系结构主要如下图所示: JVM体系结构 运行时数据区域 在上图中我们可以清楚地看到,JVM在执行Java程序的过程中会把它管理的内存划分为若干个不同的数据区域,分别是程序计数器.Java虚拟机栈

深入理解Java虚拟机笔记---内存区域

Java虚拟机在执行Java程序过程中会把它所管理的内存划分为若干个不同的数据区域.这些区域有自各的用途,以及创建及销毁时间,有的区域随着虚拟机进程的启动而存在,有些区域则是依赖用户线程的启动和结束而建立和销毁.根据<Java虚拟机规范(第2版)>规定,Java虚拟机管理的内存区域包括以下几个运行时数据区域,下如图 1.程序计数器(Program Counter Register) 程序计数器是一块较小的内存空间,它的作用可以看做是当前线程所执行的字节码的行号指示器.字节码解释器工作时就是通过

深入理解Java虚拟机二之Java内存区域与内存溢出异常

运行时数据区域 1.线程独有的内存区域 PROGRAM COUNTER REGISTER 程序计数器 程序计数器空间较小,是当前线程执行字节码的行号指示器,字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令. 如果线程执行的是Java方法,记录的是正在执行的虚拟机字节码指令的地址:如果执行的是Native方法,则为空 VM Stack 虚拟机栈 虚拟机栈生命周期与线程相同.每个Java方法执行时都会创建 原文地址:https://www.cnblogs.com/ggza