JVM GC ROOT分析

GC Root原理通过引用可达性分析确定对象是否可回收。主要包括虚拟机栈中的本地变量、static成员、常量引用、本地方法栈变量、类加载器和线程等。这些对象的存在使得它们能直接或间接引用其他对象,防止被当作垃圾回收。
摘要由CSDN通过智能技术生成


GC root原理:通过对枚举GCroot对象做引用可达性分析,即从GC root对象开始,向下搜索,形成的路径称之为 引用链。如果一个对象到GC roots对象没有任何引用,没有形成引用链,那么该对象等待GC回收,换而言之,如果减少内存泄漏,也就是切断引用链,常见的GCRoot对象如下:

1、虚拟机栈中的本地变量
能成为 GC Root,譬如各个线程被调用的方法堆栈中使用到的参数、局部变量、临时变量,

那么这个是什么?这个不就是我们在栈针中看到的这个吗?

 

那么为什么他能成GCROOT呢?或者他为什么能成为指向的依据呢?

我这个局部变量表为什么存在,因为他有栈针存在,因为栈针中有局部变量表的存在。

那么然后呢,栈针又为什么存在?

它对应的是一个方法的执行,那么然后呢?

他既然是对应一个方法的执行的话,说明有线程在调用这个方法。也就意味着线程中(栈针)的局部变量正在使用着。如果把它称之为GC ROOT的候选者的话,我认为是合适的,因为如果把这里局部变量比如op2,为什么能够成为,因为他被正在引用着。这个对象又有可能在引用其他对象,然后被引用的其他对象又有可能在引用其他对象,只要由op2这个对象去触发,能够去找到最终的一个对象,假如你有一个对象preson.这个对象经过由op2触发的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

s_nshine

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值