Java具备良好的垃圾收集特性,也就是GC是整个Java之中的最重要的安全保证,它可以保证即使再蠢的开发者也能够写合理的代码来。整个JVM中的GC的处理机制:对不需要的对象进行标记,而后进行清除.
JDK 1.8之后将最初的永久代内存空间取消了为了将HotSpot与JRockit两个虚拟机标准联合为一个.
新生代:新的对象和没有达到一定“年龄”的对象对象存放空间(活跃对象)
老年代:被长时间使用的对象,老年代空间要相对较大
元空间:一些操作的临时对象,如方法中的临时对象,直接使用物理内存
注意:永久代和元空间都是存放临时对象的,但是永久代使用的是JVM直接分配的内存,而元空间使用的是物理内存
java所有的数据都会保存在JVM的堆内存之中,但是在实际的开发之中经常会创建许多的临时对象,也会有一些常驻对象存在,所以为了保证GC的性能,就要进行垃圾回收。
GC的处理流程
注意:在整个GC的流程之中是 针对新生代和老年代进行内存清理的操作,而元空间和永久代都不在GC的范围之内。
重要:
1. 当新创建一个对象的时候,那么对象一定需要在堆内存中分配内存空间。所以就需要对该对象申请内存空间
2.
首先会判断Eden区中是否有充足的内存空间,如果有,那么直接将对象保存在Eden区中
3.
如果此时Eden中内存空间不足,那么会自动执行一个Minor
GC的操作,将伊甸园区的无用的内存空间进行清理,清理之后
继续判断伊甸园区的内存空间是否充足。如果充足,那么将对象直接在疑点园区中进行内存分配。
4.
如果执行了MinorGC之后发现伊甸园区的内存依然不足,则会对存活区进行判断,如果存活区内存足够。那么将伊甸园区的
一部分活跃对象保存到存活区,随后继续判断伊甸园区内存,如果够进行新对象的内存分配。
5.
如果此时存活区没有足够的内存空间,则继续判断老年区。如果老年区的内存空间充足,则将存活的部分活跃对象保存到
老年代,而后存活区会出现剩余空间。随后将伊甸园区的活跃对象保存对象,
然后在伊甸园区开辟空间,保存新对象。
6.
如果此时老年代也没有剩余空间,则执行MajorGC(FullGC),清理老年代内存
7.
如果执行了FullGC之后依然无法保存对象,就会产生OOM异常“OutofMemoryError”。
解释的是:StackOverError是由于栈的深度过大由和栈帧有关的异常,请看第一篇。而OutofMemoryError是由于堆内存引起的。