GC(未完待续)

借鉴【JAVA核心】Java GC机制详解_老莫的博客-CSDN博客_javagc

https://blog.csdn.net/weixin_41835916/article/details/81530733(https://blog.csdn.net/weixin_41835916/article/details/81530733)

  • 这篇很乱,期末周,工科背市场营销已经傻了,我不知道在写啥,主要可以看上面两篇,可以以第一篇为学习主线,第二篇为辅第二篇的算法很详细
  • 什么是GC

如何及时的把不再使用的对象清除将内存释放出来,这就是GC要做的事。JVM在进行GC时,并不是对这三个区域统一回收。 大部分时候,回收都是新生代

  • GC的作用区

  • GC的对象

    需要进行回收的对象就是已经没有存活的对象,判断一个对象是否存活常用的有两种办法:引用计数和可达分析。

    (1)引用计数:每个对象有一个引用计数属性,新增一个引用时计数加1,引用释放时计数减1,计数为0时可以回收。此方法简单,无法解决对象相互循环引用的问题。
    引用计数是垃圾收集器中的早期策略。在这种方法中,堆中每个对象实例都有一个引用计数。当一个对象被创建时,就将该对象实例分配给一个变量,该变量计数设置为1。当任何其它变量被赋值为这个对象的引用时,计数加1(a = b,则b引用的对象实例的计数器+1),但当一个对象实例的某个引用超过了生命周期或者被设置为一个新值时,对象实例的引用计数器减1。任何引用计数器为0的对象实例可以被当作垃圾收集。当一个对象实例被垃圾收集时,它引用的任何对象实例的引用计数器减1。
    优点:实现简单,判断效率高
    缺点:很难解决对象之间的相互循环引用,所以java语言并没有选用引用计数法管理内存

public class ReferenceFindTest {
    public static void main(String[] args) {
        MyObject object1 = new MyObject();
        MyObject object2 = new MyObject();
 
    object1.object = object2;
    object2.object = object1;

    object1 = null;
    object2 = null;
}

这段代码是用来验证引用计数算法不能检测出循环引用。最后面两句将object1和object2赋值为null,也就是说object1和object2指向的对象已经不可能再被访问,但是由于它们互相引用对方,导致它们的引用计数器都不为0,那么垃圾收集器就永远不会回收它们。

(2)可达性分析(Reachability Analysis):从GC Roots开始向下搜索,搜索所走过的路径称为引用链。当一个对象到GC Roots没有任何引用链相连时,则证明此对象是不可用的。不可达对象。

2、可达性分析算法(根搜索算法)
可达性分析算法是从离散数学中的图论引入的,程序把所有的引用关系看作一张图,从一个节点GC ROOT开始,寻找对应的引用节点,找到这个节点以后,继续寻找这个节点的引用节点,当所有的引用节点寻找完毕之后,剩余的节点则被认为是没有被引用到的节点,即无用的节点,无用的节点将会被判定为是可回收的对象。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wBKdje02-1641553055254)(C:\Users\17730\AppData\Roaming\Typora\typora-user-images\image-20220107185225256.png)]

在Java语言中,可作为GC Roots的对象包括下面几种:
a) 虚拟机栈中引用的对象(栈帧中的本地变量表);
b) 方法区中类静态属性引用的对象;
c) 方法区中常量引用的对象;
d) 本地方法栈中JNI(Native方法)引用的对象。

  • GC的工作

JVM在进行GC时,并不是对这三个区域统一回收。 大部分时候,回收都是新生代~

●新生代

●幸存区(form,to)

●老年区 GC两种类:轻GC (普通的GC), 重GC (全局GC) GC常见面试题目:

●JVM的内存模型和分区~详细到每个区放什么?

图 JVM内存模型和分区

●堆里面的分区有哪些? Eden, form, to, 老年区,说说他们的特点!

●GC的算法有哪些? 标记清除法,标记整理,复制算法,引用计数器

●轻GC和重GC分别在什么时候发生?

算法:

图 复制算法大致图

●好处:没有内存的碎片~

●坏处:浪费了内存空间~ :多了一半空间永远是空to。假设对象100%存活(极端情况) 复制算法最佳使用场景:对象存活度较低的时候;

引用计数法:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-845KgRmJ-1641553055255)(C:\Users\17730\AppData\Roaming\Typora\typora-user-images\image-20220107182845665.png)]

引用计数法:

[外链图片转存中…(img-845KgRmJ-1641553055255)]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值