垃圾回收机制(GC)小结

目录

1、需要GC的内存区域

2、判断GC对象是否存活

2.1 引用计数:

2.2 可达性分析(Reachability Analysis):

3 、标记死亡对象

3.1 第一次标记:

3.2 第二次标记

4、GC常用算法

1.标记-清除算法(mark and sweep):

2.标记-整理算法:

3.复制算法(copying):

4.分代收集算法(generation):

5、新生代与老年代

1、新生代(Young Generation)

2、年老代(Old Generation)


1、需要GC的内存区域

jvm 中,程序计数器、虚拟机栈、本地方法栈都是随线程而生随线程而灭,栈帧随着方法的进入和退出做入栈和出栈操作,实现了自动的内存清理,因此,我们的内存垃圾回收主要集中于 java 方法区中,在程序运行期间,这部分内存的分配和使用都是动态的。

2、判断GC对象是否存活

判断一个对象是否存活常用的有两种办法:引用计数和可达分析:

2.1 引用计数:

堆中的对象每被引用一次,则计数器加1,每减少一个引用就减1,当对象的引用计数器为0时可以被当作垃圾收集。

优点:算法执行效率高,实现起来简单。

缺点:无法检测出对象之间的循环引用现象。如两个对象互相引用时,他们的引用计数永远不可能为0。

Java 没有选择使用引用计数算法管理内存。

2.2 可达性分析(Reachability Analysis):

可达性分析算法是把所有的引用关系看作一张图,从一个结点根对象(GC ROOT)开始,寻找对应的引用结点。找到这个结点以后,继续寻找这个结点的引用结点。当所有的引用结点寻找完毕之后,剩余的结点则被认为是没有被引用到的结点,即可以当作jvm垃圾回收的目标。

Java中可作为GC Root的对象有:

1.虚拟机栈中引用的对象。

2.本地方法栈引用的对象。

2.方法区中静态属性引用的对象。

3.方法区中常量引用的对象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值