关于Java垃圾收集器GC处理的深入分析

GC在Java中的核心功能就是对内存的分配和回收,对于GC 的理解不要局限于只是垃圾收集,GC决定了内了存的分配。最常见的情况就是当开发者创建一个对象后,GC就会监视这个对象的内存地址、大小和状态。对象的引用会放在占内存中,对象的具体内容存储在堆内存中。当GC检测到堆中某个对象不再被栈所引用,就会不定期的对这个堆内存中板寸的对象进行回收。有了GC开发者不会在担心内存的释放泄漏问题。

在Java中垃圾收集有多种不同的处理分类:

  1. 引用计数:一个实例化对象,如果程序使用了这个引用对象,引用计数为1,当一个对象使用完毕,引用计数减一,当引用计数为0时,则可以回收。
  2. 跟踪收集:从root set(包括当前正在执行的线程、全局或者静态变量、JVM Handles、JNDI Handles)开始扫描有引用的对象,如果某个对象不可到达,则说明这个对象已经死亡,GC可对其进行回收。也就是说如果A对象引用了B对象的内存,虚拟机会记住这个引用路径,如果一个对象没有在路径图中,就会被回收。
  3. 基于对象跟踪的分代增量收集:所有对象回收要根据堆内存的结构划分来进行收集,基于对象跟踪,是由跟踪收集发展而来的,分代是指对堆进行合理的划分,JVM将整个堆分为三代:新生代、年老代、持久区。

新生代的生存周期比较短,GC对这些对象的进行回收时采用复制拷贝算法。新生代young又分为eden,survivor1(from space)survivor2 (to space)。eden是下每个对象创建的时候才会分配的空间,当eden无法分配时,自动触发一次Minor GC,当每次GC执行执行时就会将eden和survivor1的对象拷贝到survivor2中,eden和survivor1中被清空。当GC 执行下次回收时将eden和survivor2中的对象拷贝到survivor1中,同时清空eden和survivor2。按照此类顺序一次执行,经过数次回收将依然存活的对象复制到年老代。

当对象从新生代保存到年老代,会检测年老代的剩余空间是否大于要晋升对象的大小。如果小于,就直接进行一次Full GC(对整个堆进行扫描和回收,但是Major GC除外),这样就会让年老代腾出更多的空间。然后支撑性Minor GC就把新生代的对象复制到年老代。
如果大于,就会根据条件进行Minor GC 和Full GC回收。

持久区:存放加载进来的类信息,包括方法,属性,对象池等,满了之后可能会引起Out Of Memory 错误。
元空间(MetaSpace)持久化的替换者,直接使用主机内存进行存储。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值