gc回收算法
回收的逻辑:
TestObj obj = new TestObj();
obj1 = obj;
说明:
new TestObj() 就是对象,在Heap里面
obj 就是对象的引用,在栈里面,栈里面保存的就是基础变量和对象的引用,
在这里就是 obj obj1,这都是对象的引用;因为对象的内容在堆里面,所以随便改变obj obj1 一个变动,另外一个也会变动
- 引用计数器进行回收,就是一个对象每引用一次就会加1, 引用结束则减1,如果引用次数0,则回收,
缺陷:
TestObj obj = new TestObj();
TestObj1 obj1 = new TestObj1();
obj1 = obj;
obj = obj1;
- 这就涉及到了 循环引用的问题,会导致OOM ,所以java 不再使用这个引用计数器
- 可达性分析算法–排除法
垃圾对象,就是那些没有被用的对象,
gc root 就是我们正在使用的对象,根据正在使用的对象使用排除法,排除掉没有在使用的对象,剩下的就是非垃圾对象;
GCRoot 就是 非垃圾对象
1.栈中的引用变量
2. 静态变量
3. 正在运行的线程
根据这些对象找到 是否被使用,只要没有被使用的就是垃圾对象。
如何根据GCRoot 找到关联的所有的对象 — 可达链
4. 可达链是根据 引用的这个对象,绘制代码可达链
private TestObj testGC(){
TestObj obj1 = new TestObj();
TestObj obj2 = new TestObj();
TestObj obj3 = new TestObj();
obj1.setPram1(obj2.getPram1());
obj1.setPram1(obj3.getPram1());
obj2 = null;
return obj1;
上面代码说明:
obj2= null ;导致obj2引用的对象已经不可达
obj3 引用的对象 直到这个方法退出才算不可达
obj1 引用的对象直到方法返回都一直可达