GC回收

强引用、软引用、弱引用、虚引用

  • 强引用,使用根可达法未找到的对象,被认为是强引用。GC会定期随机删除
  • 软引用,通过SoftReference类创建的对象,被认为是软引用。在GC异常前必然回收。
// Worker实例 Worker a = new Worker 0 ; // a 为强引用 // 使用完了a,将它设置为soft 引用类型,并且释放强引用; SoftReferencesr sr = new SoftReference(a) // sr 为软引用
  • 弱引用,通过WeakReference类创建的对象,被认为是弱引用。每次GC都会回收。
//100M的缓存数据 byte[] cacheData = new byte[100 * 1024 * 1024]: //将缓存数据用弱引用持有 WeakReference<byte > cacheRef = new WeakReference<>(cacheData);
  • 虚引用

为什么young区被被划分为S1和S2

image
为了减少碎片化。
  堆的内存空间分配的不连续的,也就导致GC过滤后堆的空间成碎片状。如果过于碎片,在创建大的对象时,没有一个完整的空间可以存放对象,会导致每次创建都要GC一下。
  为了减少此现象,出现了S1区和S2区。

特性: S1区和S2区,必然存在一个空间是空,一个空间是连续存放。
现象:

  1. 当GC时,将伊甸区年龄为15的对象与S1区的所有对象都进行GC
  2. 将剩余的对象放置到S2区中
  3. 此时,伊甸区保存年龄15岁以下的对象,S1区为空。S2区保存连续存放的对象。
  4. 再次GC时,数据存放到S1区,S2区为空
    结果:
    伊甸区可以有更多的空间去存放对象。

如何去判断堆中的对象是否为垃圾

1. 引用计数法
  从对象出发,有一个引用,计数为1,有两个引用,计数为2。计数等于0,视为无调用,就是垃圾。
  但,对于对象相互的情况,无法处理。
2. 跟可达法(jvm 用这个)
  从GC Root出发去找对象,找到的是根可达对象,没找到的就是垃圾。
  GC Root,可以是栈(局部变量表中的数据),也可以是常亮池中的数据。


__EOF__

本文作者之士咖啡
本文链接https://www.cnblogs.com/zz-1q/p/18008337.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   之士咖啡  阅读(16)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示