Java 中的垃圾回收机制只作用域堆(Heap)和方法区中
JVM在进行GC时,并不是对这三个区域统一回收。大部分时候,回收的是新生代~
- 新生代(Eden Space)
- 幸存区(from,to)
- 老年区
GC算法
-
引用计数法:
-
复制算法:
每次GC后伊甸园区(Eden)和to区会是空的:
- 好处: 没有内存的碎片~
- 坏处:浪费了内存空间~,多了一半空间永远是空 to。假设对象100%存活(极端情况)
复制算法最佳使用场景:对象存活度较低的时候;新生区~
-
标记清除算法
- 优点:不需要额外的空间!
- 缺点:两次扫描,严重浪费时间,会产生内存碎片。
-
标记压缩算法
该算法解决了标记清除算法出现内存碎片的问题,但相应的时间成本也增加了。
总结
- 内存效率 : 复制算法 > 标记清除算法 > 标记压缩算法 (时间复杂度)
- 内存整齐度 : 复制算法 == 标记压缩算法 > 标记清除算法
- 内存利用率 :标记清除算法==标记压缩算法 > 复制算法
没有最好的算法,只有最合适的算法:分代收集算法
年轻代
- 存活率低 复制算法
老年代
- 标记清除(内存碎片不是太多) + 标记压缩混合 实现