JAVA GC机制一

首先在这里给大家推荐《深入理解jvm虚拟机》这本书,我只是一名搬用工
GC 全称:Garbage Collections, java的垃圾回收机制,目的是为了不需要像C语言一样由开发人员来对内存进行维护和释放,由系统来动态的分配内存,避免内存溢出

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

1运行时数据区域

每个线程单独存储,互不影响

1、程序计数器

2、java虚拟机栈

3、本地方法栈

各个线程共同持有

4、方法区 5、java堆

1、程序计数器

程序计数器(Program Counter Register)是一块较小的内存空间,它的作用可以看 做是当前线程所执行的字节码的行号指示器。 如果线程正在执行的是一个Java方法,这个计数器记录的是正在执行的虚拟机字节 码指令的地址;如果正在执行的是Natvie方法,这个计数器值则为空(Undefined )。此 内存区域是唯一一个在Java虚拟机规范中没有规定任何DutDfMemoryError情况的区域。

2、 Java虚拟机栈

与程序计数器一样,Java虚拟机栈(Java Virtual Machine Stacks)也是线程私有的, 它的生命周期与线程相同。虚拟机栈描述的是Java方法执行的内存模型:每个方法被执 行的时候都会同时创建一个栈帧( Stack Frame)用干存储局部变量表、操作栈、动态 链接、方法出口等信息。每一个方法被调用直至执行完成的过程,就对应着一个栈帧在 虚拟机栈中从入栈到出栈的过程。
“栈”就是虚拟机栈中的局部变 量表部分。
局部变量表存放了编译期可知的各种基本数据类型(hoolean, byte, char. short.int, float, long, double)、对象引用(reference类型,它不等同于对象本身,根据不同的虚拟机实现 。局部变量表所需的内存空间在编译期间完成分配,当进入一个 方法时一,这个方法需要在帧中分配多大的局部变量空间是完全确定的,在方法运行期间 不会改变局部变量表的大小。

3本地方法栈

木地方法栈C Native Method Stacks)与虚拟机栈所发挥的作用是非常相似的,其 区别不过是虚拟机栈为虚拟机执行Java方法(也就是字节码)服务,而本地方法栈则 是为虚拟机使用到的Native方法服务

4 Java堆

对于大多数应用来说,Java堆 ( Java Heap )是Java虚拟机所管理的内存中最大的 一块。Java堆是被所有线程共享的一块内存区域,在虚拟机启动时创建。此内存区域的 唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存。这一点在Java虚 拟机规范中的描述是:所有的对象实例以及数组都要在堆上分配,但是随着JIT编译器 的发展与逃逸分析技术的逐渐成熟,栈上分配、标量替换优化技术将会导致一些微妙 的变化发生,所有的对象都分配在堆上也渐渐变得不是那么“绝对”了

Java堆是垃圾收集器管理的主要区域,因此很多时候也被称做“GC堆”。如果从内存回收的角度看,由于现在 收集器从本都是采用的分代收集算法,所以Java堆中还可以细分为:新生代和老年代; 再细致一点的有Eden空间、From Survivor空间、To Survivor空间等。如果从内存分配

5方法区

方法区(Method Area)与Java堆样,是各个线程共享的内存区域,‘用于存 储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。虽 然lava虚拟机规范把方法区描述为堆的一个逻辑部分,但是它却有一个别名叫做Non- Heap(非堆),目的应该是与lava堆区分开来。

你可能感兴趣的:(JAVA GC机制一)