垃圾回收

2019-08-25  本文已影响0人  编程喵喵

GC

引用计数算法

通关在对象头中分配一个空间来保存该对象被引用的次数。如果该对象被引用则加1,删除引用则减1,当对象的引用计数为0时,那么该对象回收。
引用计数的问题,如果2个对象互相引用则永远不会回收。

可达性分析算法

通过GC roots的一些作为起点,向下搜索,当一个对象到GC roots没有任何链相连时,则证明该对象不可用。解决了引用计数无法解决的“循环依赖”问题。

可作为GC root对象

怎能回收垃圾

标记-清除算法 —>内存碎片问题
复制算法 解决碎片问题,平分代价太高
标记整理算法 内存变动频繁,效率低
分代收集算法 组合拳
Java堆分为新生代和老年代
新生代:对象存活量低,复制算法
老年代:对象存活量高,另外两种算法

Java堆

新生代 分为Eden区 和 Survivor区(分为From和To区):减少被送到老年代的对象,减少major GC的次数
minor GC回收,Eden清空,无法回收的对象到From区,Survivor的两个分区,每次minor GC,复制对象,一个区域为空,减少内存碎片
老年代 占对内存2/3 在major GC才会清理,每次GC都是STW 采用标记-整理算法
大对象 长期存活对象
动态对象年龄

上一篇 下一篇

猜你喜欢

热点阅读