一、垃圾回收机制,从概念角度
1.1、什么是垃圾
无用对象所占用的内存空间
1.2、如何定位垃圾
- 引用计数法
- 可达性分析(标记算法
- 为防止漏报 stop-the-world机制(GC卡顿,full Gc 长卡顿)
1.3、垃圾回收的三种方式
- 清除
- 压缩
- 复制
二、垃圾回收机制,从内存的角度
jvm 的对象内存分配在堆上。
2.1、 jvm 的堆分为新生代,老生代
新生代= eden(伊甸区) + (幸存区)from + (幸存区)to
from to 是两个等大的survivor区(幸存区)
- 新对象,实例化时内存分配在 eden 区,eden区耗尽的时,触发minor GC
- minor gc 时把eden区和from区剩余的对象copy到to区,from to 功能交换。反复多次复制后还存活的对象(比如15), 进入到老年代
- minor gc 采用标记-复制算法,标记复制算法存在一个老生代可能引用新生代对象的问题,为了解决这个问题并减少full gc 引入卡表。
- 新生代对象被老年代对象引用则称为脏卡,标记脏卡的方法 <<= 写屏障
2.2、垃圾回收器
minor gc:新生代垃圾回收 (标记-复制算法)
垃圾回收器:
- Serial,单线程
- Parallel Scavenge,多线程
- Parallel New。多线程,重吞吐
major gc:老生代垃圾回收
垃圾回收期:
- Serial Old 标记压缩算法 单线程
- Parallel Old 标记压缩算法 多线程
- CMS 标记清除算法