Java垃圾回收机制(Garbage Collection)

垃圾回收机制

Java引入了垃圾回收机制,令C++程序员头疼的内存管理问题迎刃而解,Java程序员可以将更多的精力放到业务逻辑上而不是内存管理工作上,大大提高了开发效率

认识垃圾回收机制

垃圾回收机制可以自动清空无用对象,C++垃圾回收就像学校食堂一样,需要用餐人员自己回收餐盘,如果没回收就会导致这个位置没法坐人,如果每个人都不回收就会造成瘫痪,无法营业,就好比程序。Java就好比在外面饭馆吃饭,无需你回收餐盘,你可以吃干净抹嘴走人,会有餐馆的服务员帮你回收盘子,这样就方便了你也节约了时间。

垃圾回收过程

任何一种垃圾回收算法一般都要做两件事情:
1.发现无用的对象
2.回收无用对象占用的内存空间。

垃圾回收相关算法

引用计数法

堆中每个对象都有一个引用计数,被引用一次,计数加1,被引用变量值变为null,则计数减一,直到计数为0,则表示无用对象,优点:算法简单。缺点:“循环引用的无用对象”无法被识别。

引用可达法(根搜索算法)

程序把所有的引用关系看作一张图,从一个节点GC ROOT 开始,寻找对应的引用节点,找到这个节点后,继续寻找当前节点的引用节点,当所有节点寻找完毕后,剩余节点被认为是没有被引用到的节点,即无用的节点。

通用的分代垃圾回收机制

分代垃圾回收机制,是基于这样一个事实:不同的对象的生命周期是不一样的。因此,不同生命周期的对象可以采取不同的回收算法,以便提高回收效率,我们将对象分为三种状态:年轻代、年老代、持久代。JVM将堆内存划分为Eden、Survivor、Tenured/Old空间。

年轻代

所有新生成的对象首先都是放在Eden区。年轻代的目标就是尽可能快速的搜集掉那些生命周期短的对象,对应的是Minor GC,每次Minor GC会清理年轻代的内存,算法采用效率较高的复制算法,频繁的操作,但是会浪费内存空间。当“年轻代”区域存放满对象后,就将对象存放到年老代区域。

年老代

在年老代中经历了N(默认15)次的垃圾回收后仍然存活的对象,就会被放到年老代中。因此,可以认为年老代中存放的都是一些生命周期较长的对象。年老代的对象越来越多,我们就需要启动Major GC和Full GC(全量回收),来进行一次大扫除,全名清理年轻代区域和年老代区域。

持久代

用于存放静态文件,如Java类、方法等。持久代对垃圾回收没有显著影响。

名词解释

·Minor GC:

用于清理年轻代区域。Eden区满了就会触发一次Minor GC.清理无用对象,将有用对象复制到“Survivor1”、“Survivor2”区中(这两个区,大小空间相同,同一时刻只有一个区在运行,另一个为空)

·Major GC:

用于清理年老代区域。

·Full GC:

用于清理年轻代、年老代区域。成本较高,会对系统性能产生影响。

垃圾回收过程

1、新创建的对象,绝大多数都会存储在Eden中。
2、当Eden满了(达到一定比例)不能创建新对象,则触发垃圾回收机制(GC),将无用对象清理掉,然后剩余对象复制到某个Survivor中,如S1,同时清空Eden区。
3、当Eden再次满了,会将S1中的不能清空的对象存到另一个Survivor中,如S2,同时将Eden区中不能清空的对象也复制到S1中,保证Eden和S1的无用对象,均被清空。
4、重复多次(默认15次)Survivor中没有被清理的对象,则会被复制到年老代Old(Tenured)中。
5、当Old区满了,则会触发一个一次完整地垃圾回收(Full GC),之前年轻代的垃圾回收被称为(Minor GC).

原创技术分享,您的支持将鼓励我继续创作
0%