两种垃圾回收算法:引用计数算法、可达性分析算法(JVM采用的)
引用计数算法的缺点:很难解决对象之间相互循环引用的问题。
帧栈中的对象随着方法或线程的结束,生命周期结束,内存回收。
GC主要管理的是JAVA堆(对象的成员变量等,针对对象)和方法区(类的静态对象,常量等,针对类)
可作为GC Roots的对象包括下面几种:
1.虚拟机栈(帧栈中的本地变量表)中引用的对象。--方法中引用的对象
2.方法区中类静态属性引用的对象。--类的static变量
3.方法区中常量对象的引用。--常量
4.本地方法栈中引用的对象。--native方法
回收的过程:如果对象在进行可达性分析后发现没有与GC Roots相连接的引用,它将会被第一次标记并且进行一次筛选,筛选的条件是此对象是否有必要执行finalize()方法,当对象没有重写finalize()方法或者finalize()方法已经被调用过,这两种情况都视为没有必要执行finalize()方法。如果有必要执行finalize()方法,对象被放入F-Queue的队列中,虚拟机会有一个自动建立的、低优先级的线程去执行它,对象可以在finalize()方法中完成自救,即将自己的引用连接到GC Roots。
finalize()只会被调用一次,并且不能保证会执行完。不要使用重写该方法。