Java具备良好的垃圾收集特性,也就是GC是整个Java之中的最重要的安全保证,它可以保证即使再蠢的开发者也能够写合理的代码来。整个JVM中的GC的处理机制:对不需要的对象进行标记,而后进行清除. java堆内存模型 JDK1.7以前 JDK1.8 JDK 1.8之后将最初的永久代内存空间取消了为了将HotSpot与JRockit两个虚拟机标准联合为一个. 新生代:新的对象和没有达到一定“年龄”的对象对象存放空间(活跃对象) 老年代:被长时间使用的对象,老年代空间要相对较大 元空间:一些操作的临时对象,如方法中的临时对象,直接使用物理内存 注意:永久代和元空间都是存放临时对象的,但是永久代使用的是JVM直接分配的内存,而元空间使用的是物理内存 GC的流程(非常重要) 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是由于堆内存引起的。
点赞 评论

相关推荐

把球:这个听过,你加了就会发现是字节的hr
点赞 评论 收藏
分享
牛客网
牛客企业服务