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

为了减少碎片化。
堆的内存空间分配的不连续的,也就导致GC过滤后堆的空间成碎片状。如果过于碎片,在创建大的对象时,没有一个完整的空间可以存放对象,会导致每次创建都要GC一下。
为了减少此现象,出现了S1区和S2区。
特性: S1区和S2区,必然存在一个空间是空,一个空间是连续存放。
现象:
- 当GC时,将伊甸区年龄为15的对象与S1区的所有对象都进行GC
- 将剩余的对象放置到S2区中
- 此时,伊甸区保存年龄15岁以下的对象,S1区为空。S2区保存连续存放的对象。
- 再次GC时,数据存放到S1区,S2区为空
结果:
伊甸区可以有更多的空间去存放对象。
如何去判断堆中的对象是否为垃圾
1. 引用计数法
从对象出发,有一个引用,计数为1,有两个引用,计数为2。计数等于0,视为无调用,就是垃圾。
但,对于对象相互的情况,无法处理。
2. 跟可达法(jvm 用这个)
从GC Root出发去找对象,找到的是根可达对象,没找到的就是垃圾。
GC Root,可以是栈(局部变量表中的数据),也可以是常亮池中的数据。

浙公网安备 33010602011771号