Java语言是不需要程序员手动管理内存的,jvm虚拟机自动管理内存,进行垃圾回收,这里说几种常用的垃圾回收算法以
1. 复制算法:
此算法把内存空间分为两个相等的区域,每次只使用其中一个区域,垃圾回收时,遍历当前使用区域,把正在使用中的对象复制到另外一块区域当中,此算法每次只处理正在使用中的对象,因此复制成本比较小,同时复制过去以后还能进行相应的内存整理,不会出现碎片问题,缺点是需要两倍的内存空间
2. 标记-清除算法:
此算法执行分为两阶段,第一阶段从引用根节点开始标记所有被引用的对象,第二阶段遍历整个堆,把未标记的对象清除,此算法需要暂停整个应用,同时会产生虽碎片
3. 标记-整理算法:
此算法结合了标记-清除和复制两个算法的优点,也分两阶段,第一阶段从根节点开始标记所有被引用对象,第二阶段遍历整个堆,把清除未标记对象并且把存货对象压缩到堆中的一块,按排序倒放,此方法避免了标记清除的碎片问题,同时也避免了复制算法的空间问题
4. 垃圾收集器分类:
- 次收集:当年轻代堆空间紧张时会被触发,相当于全收集而言,收集间隔较短
- 全收集:当老年代或者持久代堆空间满了,会触发全收集操作,可以使用system.gc()方法来显式的启动全收集,全收集一般根据大小的不同,需要的时间也不同,不会超过2.3秒
5. 堆中的7种分代垃圾收集器:
5.1 新生代收集器:
- 串行收集器(Serial)
- 并行收集器(parNew)
- Parallel Scavenge收集器
5.2 老年代收集器:
- Serial Old收集器
- Parallel Old收集器
- CMS收集器
5.3 分区收集器:
- G1收集器(Garbage-First)