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,可以是栈(局部变量表中的数据),也可以是常亮池中的数据。

posted @ 2024-02-06 11:38  之士咖啡  阅读(6)  评论(0编辑  收藏  举报